`
hzy3774
  • 浏览: 992978 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
社区版块
存档分类
最新评论

PHP利用天气网API获取天气信息

 
阅读更多

    中国天气网提供了一些查询天气的API,访问时返回天气信息的JSON格式数据,解析就可以得到天气信息:

http://www.weather.com.cn/data/sk/101281601.html
http://www.weather.com.cn/data/cityinfo/101281601.html
http://m.weather.com.cn/data/101281601.html

后面一串数字为城市代码。

 返回的utf-8字符串

{"weatherinfo":{"city":"东莞","cityid":"101281601","temp":"22","WD":"东风","WS":"1级","SD":"90%","WSE":"1","time":"08:20","isRadar":"0","Radar":""}}

 所以首先要将城市名转换为城市代码,最简单的办法是通过读取一个文本文件来获取:

格式如:

101010100=北京 
101010200=海淀
101010300=朝阳
101010400=顺义
101010500=怀柔
101010600=通州
101010700=昌平
101010800=延庆
101010900=丰台
101011000=石景山
101011100=大兴

 

文本文件和PHP文件放在同一目录下;
于是PHP代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
	<head>
		<meta http-equiv="content-type" content="text/html; charset=utf-8" />
		<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
		<script src="http://libs.baidu.com/bootstrap/2.0.4/js/bootstrap.min.js"></script>
		<link href="http://libs.baidu.com/bootstrap/2.0.4/css/bootstrap.min.css" rel="stylesheet"/>
		<title>天气查询简单版</title>
	</head>
	<body>
		<form class="form-horizontal" action="" method="post">
			<legend>
				Weather
			</legend>
			<div class="control-group">
				<label class="control-label" for="idCity">城市:</label>
				<div class="controls">
					<input name="city" type="text" name="city" id="idCity" placeholder="请输入城市名字" maxlength="64">
				</div>
			</div>
			<div class="control-group">
				<div class="controls">
					<button type="submit" class="btn btn-primary" style="margin: 10px">
						确定
					</button>
					<button type="reset" class="btn btn-inverse" style="margin: 10px">
						重置
					</button>
				</div>
			</div>
		</form>
		<hr/>
		<?php
		header("Content-Type: text/html; charset=utf-8");
		function getWeather($city) {
			$wcity = file_get_contents("wcity.txt");
			$pattern = '/([0-9]+)=' . $city . '/';
			preg_match($pattern, $wcity, $matches, PREG_OFFSET_CAPTURE);
			if ($matches == null) {
				return null;
			}
			$cityID = $matches[1][0];
			$data = file_get_contents('http://www.weather.com.cn/data/sk/' . $cityID . '.html');
			return json_decode($data, true);
		}

		if ($_POST != null && $_POST["city"] != null) {
			$weather = getWeather($_POST["city"]);
			if ($weather == null) {?>
			<div class="alert alert-block" style="margin: 20px">
				<button type="button" class="close" data-dismiss="alert">
					&times;
				</button>
				<h4>警告!</h4>
				发生错误了亲,您输入的城市好像没有找到哦!
			</div>
			<?php return;
			}
			$info = $weather["weatherinfo"];
			?>
			<table class="table table-striped table-bordered" style="margin-left: 20px;width: 200px">
				<thead>
					<th>实时天气信息</th>
				</thead>
				<tbody>
			<?php
			echo "<tr><td>城市:</td><td>".$info["city"]."</td></tr>";
			echo "<tr><td>城市ID:</td><td>".$info["cityid"]."</td></tr>";
			echo "<tr><td>气温:</td><td>".$info["temp"]."℃</td></tr>";
			echo "<tr><td>风向:</td><td>".$info["WD"]."</td></tr>";
			echo "<tr><td>风力:</td><td>".$info["WS"]."</td></tr>";
			echo "<tr><td>湿度:</td><td>".$info["SD"]."</td></tr>";
			echo "<tr><td>更新时间:</td><td>".$info["time"]."</td></tr>";
			?>								
				</tbody>
			</table>
			<?php
		}
		?>
	</body>
</html>
 运行结果:


方法二:
1.可以不用文件,而是从天气网服务器动态获取城市名和ID:
当访问这个地址
服务器就会返还以下代码:
01|北京,02|上海,03|天津,04|重庆,05|黑龙江,06|吉林,07|辽宁,08|内蒙古,09|河北,10|山西,11|陕西,12|山东,13|新疆,14|西藏,15|青海,16|甘肃,17|宁夏,18|河南,19|江苏,20|湖北,21|浙江,22|安徽,23|福建,24|江西,25|湖南,26|贵州,27|四川,28|广东,29|云南,30|广西,31|海南,32|香港,33|澳门,34|台湾
2. 这时,我们就知道了省份的代码;城市的代码是在省份的基础上扩展的,知道省份代码是第一步;同时我们也知道了省份名,这样,做下拉框让用户选地区也很简单:
知道了省份我们要看这个省有些什么市,就需要依据省份代码来获取不同的文件了,例如云南是05,我们要获取云南所有州市的信息就要访问:
返回文本:
2901|昆明,2902|大理,2903|红河,2904|曲靖,2905|保山,2906|文山,2907|玉溪,2908|楚雄,2909|普洱,2910|昭通,2911|临沧,2912|怒江,2913|迪庆,2914|丽江,2915|德宏,2916|西双版纳
 3.但是,这样还不够,我们还需要继续缩小范围,比如我们要知道大理州有哪些县级市和县,就需要继续访问:
果然,返回结果:
290201|大理,290202|云龙,290203|漾濞,290204|永平,290205|宾川,290206|弥渡,290207|祥云,290208|巍山,290209|剑川,290210|洱源,290211|鹤庆,290212|南涧
 4.这时虽然可以找到所有城市名,但这个代码还不是最终的城市代码,所以还要再来一次,不如说要找宾川的代码:
 
290205|101290205
 至此,读了四次,城市名和城市代码已获取到。
当然,解析数据也可以用Javascript来完成,但是由于Ajax不支持跨域名访问,所以将数据从中国天气网的服务器上获取到本地还需要一个简单服务器脚本来做代理,它的功能只是完成将请求的文件以字符串返还Javascript来做动态数据显示,所以:
首先要写一个读取字符串的php
getstr.php
<?php
echo file_get_contents($_GET['url']);
?>
 一个使用Ajax的js文件:
ajax.js
function Ajax(recvType) {
  var aj = new Object();
  aj.recvType = recvType ? recvType.toUpperCase() : 'HTML'//HTML XML
  aj.targetUrl = '';
  aj.sendString = '';
  aj.resultHandle = null;

  aj.createXMLHttpRequest = function() {
    var request = false;
    //window对象中有XMLHttpRequest存在就是非IE,包括(IE7,IE8)
    if (window.XMLHttpRequest) {
      request = new XMLHttpRequest();
      if (request.overrideMimeType) {
        request.overrideMimeType("text/xml");
      }
      //window对象中有ActiveXObject属性存在就是IE
    } else if (window.ActiveXObject) {
      var versions = ['Microsoft.XMLHTTP', 'MSXML.XMLHTTP', 'Msxml2.XMLHTTP.7.0', 'Msxml2.XMLHTTP.6.0', 'Msxml2.XMLHTTP.5.0', 'Msxml2.XMLHTTP.4.0', 'MSXML2.XMLHTTP.3.0', 'MSXML2.XMLHTTP'];
      for (var i = 0; i < versions.length; i++) {
        try {
          request = new ActiveXObject(versions[i]);
          if (request) {
            return request;
          }
        } catch(e) {
          request = false;
        }
      }
    }
    return request;
  }

  aj.XMLHttpRequest = aj.createXMLHttpRequest();

  aj.processHandle = function() {
    if (aj.XMLHttpRequest.readyState == 4) {
      if (aj.XMLHttpRequest.status == 200) {
        if (aj.recvType == "HTML")
          aj.resultHandle(aj.XMLHttpRequest.responseText);
        else if (aj.recvType == "XML")
          aj.resultHandle(aj.XMLHttpRequest.responseXML);
      }
    }
  }

  aj.get = function(targetUrl, resultHandle) {
    aj.targetUrl = targetUrl;

    if (resultHandle != null) {
      aj.XMLHttpRequest.onreadystatechange = aj.processHandle;
      aj.resultHandle = resultHandle;
    }
    if (window.XMLHttpRequest) {
      aj.XMLHttpRequest.open("get", aj.targetUrl);
      aj.XMLHttpRequest.send(null);
    } else {
      aj.XMLHttpRequest.open("get", aj.targetUrl, true);
      aj.XMLHttpRequest.send();
    }

  }

  aj.post = function(targetUrl, sendString, resultHandle) {
    aj.targetUrl = targetUrl;

    if ( typeof (sendString) == "object") {
      var str = "";
      for (var pro in sendString) {
        str += pro + "=" + sendString[pro] + "&";
      }
      aj.sendString = str.substr(0, str.length - 1);
    } else {
      aj.sendString = sendString;
    }

    if (resultHandle != null) {
      aj.XMLHttpRequest.onreadystatechange = aj.processHandle;
      aj.resultHandle = resultHandle;
    }

    aj.XMLHttpRequest.open("post", targetUrl);
    aj.XMLHttpRequest.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    aj.XMLHttpRequest.send(aj.sendString);

  }

  return aj;
}
 网页部分代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
  <head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8" />
    <script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>
    <script src="http://libs.baidu.com/bootstrap/2.0.4/js/bootstrap.min.js"></script>
    <link href="http://libs.baidu.com/bootstrap/2.0.4/css/bootstrap.min.css" rel="stylesheet"/>
    <title>实时气温信息</title>
    <script type="text/javascript" src="./ajax.js"></script>
    <script type="text/javascript">
      function str2Array(data) {
        data = data.replace(/\|/g, "\":\"");
        data = data.replace(/,/g, "\",\"");
        data = '({\"' + data + '\"})';
        return eval(data);
      }

      function getProvince() {
        var ajax = Ajax();
        ajax.get("getstr.php?url=http://m.weather.com.cn/data5/city.xml", function(data) {
          var arr = str2Array(data);
          var prov = document.getElementById("province");
          for (var p in arr) {
            prov.options.add(new Option(arr[p], p));
          }
          prov.options.selectedIndex = 0;
          getCity(prov.value);
        });
      }

      function getCity(provId) {
        var ajax = Ajax();
        ajax.get("getstr.php?url=http://m.weather.com.cn/data5/city" + provId + ".xml", function(data) {
          var arr = str2Array(data);
          var city = document.getElementById("city");
          for (var i = city.options.length; i >= 0; i--) {
            city.remove(i);
          }
          for (var p in arr) {
            city.options.add(new Option(arr[p], p));
          }
          getTown(city.value);
        });
      }

      function getTown(provId) {
        var ajax = Ajax();
        ajax.get("getstr.php?url=http://m.weather.com.cn/data5/city" + provId + ".xml", function(data) {
          var arr = str2Array(data);
          var town = document.getElementById("town");
          for (var i = town.options.length; i >= 0; i--) {
            town.remove(i);
          }
          for (var p in arr) {
            town.options.add(new Option(arr[p], p));
          }
          getCityId();
        });
      }

      function getCityId() {
        var ajax = Ajax();
        var index = document.getElementById("town").value;
        ajax.get("getstr.php?url=http://m.weather.com.cn/data5/city" + index + ".xml", function(data) {
          var arr = str2Array(data);
          cityId = arr[index];
          showWeather(cityId);
        });
      }

      function insertTab(tab, cel1, cel2) {
        var newRow = tab.insertRow(tab.rows.length);
        var cell = newRow.insertCell(0);
        cell.innerHTML = cel1;
        var cell = newRow.insertCell(1);
        cell.innerHTML = cel2;
      }

      function showWeather(cityId) {
        if (cityId == null) {
          return;
        }
        var ajax = Ajax();
        ajax.get("getstr.php?url=http://www.weather.com.cn/data/sk/" + cityId + ".html", function(data) {
          data = '(' + data + ')';
          var info = eval(data)["weatherinfo"];
          var tab = document.getElementById("weather");

          var len = tab.rows.length;
          while(len-- > 0){
            tab.deleteRow(len);
          }

          insertTab(tab, "城市:", info["city"]);
          insertTab(tab, "城市ID:", info["cityid"]);
          insertTab(tab, "气温:", info["temp"] + "℃");
          insertTab(tab, "风向:", info["WD"]);
          insertTab(tab, "风力:", info["WS"]);
          insertTab(tab, "湿度:", info["SD"]);
          insertTab(tab, "更新时间:", info["time"]);
        });
      }

      getProvince();
    </script>
    <style type="text/css">
        select {
            width: 100px;
        }
    </style>
  </head>
  <body>
    <div style="margin: 20px">
      <legend>
        Weather
      </legend>
      <br>
      <select id="province" onchange="getCity(this.value)" ></select>
      <select id="city" onchange="getTown(this.value)" ></select>
      <select id="town" onchange="getCityId()" ></select>
      <br>
      <table id="weather" class="table table-striped table-bordered" style="width: 310px"></table>
    </div>
  </body>
</html>
 运行结果:

这样做下拉框中的数据可以动态从天气网的服务器中读取过来再动态加载,因此也不用自己做转换了。
 
如果是有图片元素的数据,直接找到图片的链接,将图片链过来就可以了。


 完。
  • 大小: 23.9 KB
  • 大小: 20.3 KB
  • 大小: 20.2 KB
分享到:
评论

相关推荐

    基于高德地图开放平台的PHP天气信息组件

    【标题】"基于高德地图开放平台的PHP天气信息组件"揭示了这个项目的核心内容,即使用PHP编程语言,结合高德地图开放平台的API,创建了一个能够获取并展示天气信息的组件。高德地图开放平台是阿里巴巴旗下的一款提供...

    基于高德地图接口的 PHP 天气信息组件包.zip

    1. `getWeather()`:通过高德地图API获取天气信息的函数,可能需要传入城市名或经纬度作为参数。 2. `parseResponse()`:解析API返回的JSON数据,将其转化为可用的PHP数组。 3. `displayWeather()`:用于格式化并...

    一个自动获取天气的PHP类

    - **方法**:如`getIP()`获取客户端IP,`locateIP()`根据IP获取地理位置,`fetchWeather()`调用API获取天气数据,`parseData()`解析返回的天气数据。 - **属性**:存储类的状态信息,如当前地理位置、天气预报等。...

    PHP飞信通知天气预报_API版

    【PHP飞信通知天气预报_API版】是一个基于PHP编程语言的项目,旨在通过调用外部天气预报API,向用户发送实时天气信息。这个系统利用了API接口从权威天气服务提供商获取数据,然后通过飞信(一种短信服务)将这些信息...

    Weather基于百度地图接口的PHP天气信息组件

    【标题】"Weather基于百度地图接口的PHP天气信息组件"是一个专门为PHP开发者设计的实用工具,它利用了百度地图开放的API服务来获取并展示实时的天气信息。这个组件简化了开发者获取地理位置天气数据的过程,使得在...

    基于高德开放平台的PHP天气信息组件

    【基于高德开放平台的PHP天气信息组件】是一款利用高德地图开放平台的API来获取并展示天气信息的PHP程序。这个组件可以帮助开发者轻松地在自己的PHP应用中集成天气查询功能,为用户提供实时的天气预报服务。下面我们...

    基于百度地图的天气查询组件

    【标题】"基于百度地图的天气查询组件"指的是一个利用百度地图API开发的程序,能够实时获取并展示特定地点的天气信息。这个组件通常用于网页或应用中,为用户提供便捷的天气查询服务。 【描述】"基于百度地图的天气...

    Weather基于高德开放平台的PHP天气信息组件

    在本例中,高德开放平台就是这样一个第三方API,它允许开发者通过API调用来获取天气信息。 【详细说明】 1. **PHP编程语言**:PHP是一种广泛使用的服务器端脚本语言,尤其适用于Web开发,可嵌入HTML中,实现动态...

    PHP 获取指定地区的天气实例代码

    然后,利用PHP的file_get_contents函数从该URL获取天气信息的HTML页面内容。 获取到HTML页面内容之后,页面内容是一个JSON格式的字符串。为了方便操作这些数据,我们使用了json_decode函数将其转换成PHP对象。这样...

    php实现实时天气预报

    通常,我们可以从各种公开的天气API获取这些信息,例如OpenWeatherMap、Weather Underground等。这些API提供了城市的温度、湿度、风速、气压等实时或近实时的气象数据,通常以JSON或XML格式返回。 在给定的文件中,...

    一个基于和风天气的php包扩展

    2. **和风天气API**: 和风天气是一家提供全球天气数据的供应商,其API允许开发者通过API调用来获取实时和预报的气象信息,包括温度、湿度、风向、风速、气压、降雨概率等。 3. **HTTP请求与响应处理**: PHP扩展可能...

    PHP的天气预报小偷

    在这个案例中,爬虫可能需要识别并解析“问天网”页面上特定的HTML标签或CSS选择器来获取天气信息。 对于“问天网”的天气预报数据,可能包含城市名、日期、最高温度、最低温度、天气状况、风向风力等多个字段。在...

    php天气预报超漂亮.rar

    开发者需要注册并获取API密钥,然后使用PHP的HTTP请求库,如cURL或者file_get_contents函数,来发送GET请求获取实时的天气信息。 其次,解析返回的JSON(JavaScript Object Notation)数据是另一个关键点。PHP提供...

    php天气预报系统定时生成htm(utf-8版).rar

    描述中提到的“php天气预报系统定时生成htm系统需要空间支持采集功能”,这表明该系统依赖于外部数据源获取天气预报信息。采集功能是系统的关键部分,它可能通过API接口或者其他网络抓取技术从权威气象网站或者其他...

Global site tag (gtag.js) - Google Analytics