使用正则表达式和REPLACE,SPLIT获得7,8,9天单个城市天气情况抓取解析代码

简介:

代码写的很凌乱,正则用得也不是很好,不过还是实现了功能,贴出代码


package com.zzk.cn;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.util.regex.Matcher;
import java.util.regex.Pattern;


public class TestSpider {

	public static void main(String[] args) {
		URL url = null;
		URLConnection conn = null;
		InputStream in = null;
		InputStreamReader isr = null;
		BufferedReader br = null;
		try {
			url = new URL("http://www.haotq.com/d_anqing.html");
			conn = url.openConnection();
			in = conn.getInputStream();
			isr = new InputStreamReader(in);
			br = new BufferedReader(isr);
			String line = "";
			String info="";
			while (null != (line = br.readLine())) {
				//System.out.println(line);
				info+=line;
			}
		
			//System.out.println(info);
			Pattern p=Pattern.compile("div\\sid=.weather_day_brief.*?</div>");//正则获取网页大致信息

			Matcher m=p.matcher(info);
			String s1="";
	    	while(m.find()) {
	    		s1=m.group();
	    		//System.out.println(s1);
	    	}
	    	
	    	String s2="";
	        Pattern p1=Pattern.compile("<br>.*<script");//正则根据br获取7,8,9天的天气信息
	    	//Pattern p1=Pattern.compile("<(/?\\s?br\\b)>");
	    	Matcher m1=p1.matcher(s1);
	    	while(m1.find()) {
	    		//System.out.println(m1.group());
	    	    s2=m1.group();
	    	}
			
	    	String[] sPlit=s2.split("<br>"); 

	    	int i=s2.length(); 
	    		String t1="";
	    		String t2="";
	    		String t3="";
	    		t1=sPlit[7];
	    		t2=sPlit[8];
	    		t3=sPlit[9];
	    		System.out.println(t1);//7天后天气
	    		System.out.println(t2);//8天后天气
	    		System.out.println(t3);//9天后天气
	    	
	    	
	    		//天气
	    	String[] sPlit1=t1.split(" "); 
	    	int i1=t1.length();
	    	System.out.println(sPlit1[1]);//白天阵雨,夜间阵雨,
	    	System.out.println(sPlit1[2]);//气温2℃~9℃
	    	System.out.println(sPlit1[3]);//北偏东风 二级
	    	
	    	String w1="";
	    	String w2="";
	    	String w3="";
	    	w1=sPlit1[1];
	    	String[] sPlit4=w1.split(",");
	    	String weather_title71=sPlit4[0].replace("白天", "");//第七天的白天的字段
	    	String weather_title72=sPlit4[1].replace("夜间", "");//第七天的夜晚的字段
            System.out.println(weather_title71);//第七天的白天天气情况
            System.out.println(weather_title72);//第七天的夜晚天气情况
	    	
	    	w2=sPlit1[2];
	    	String[] sPlit5=w2.split("~");
	    	String weather_temp71=sPlit5[0].replace("气温", "");
	    	String weather_temp72=sPlit5[1].replace("~", "").replace(",", "");
	    	System.out.println(weather_temp71);//第七天的最低气温
	    	System.out.println(weather_temp72);//第七天的最高气温
	    	
	    	w3=sPlit1[3];
	    	String[] sPlit6=w3.split(" ");
	    	String weather_winddirection71=sPlit6[0];
	    	String weather_windpower71=sPlit6[1];
	    	System.out.println(weather_winddirection71);//第七天的风向
	    	System.out.println(weather_windpower71);//第七天的风力
	    	
	    	String[] sPlit2=t2.split(" "); 
	    	int i2=t2.length();
	    	
	    	String w4="";
	    	String w5="";
	    	String w6="";
	    	w4=sPlit2[1];
	    	String[] sPlit7=w4.split(",");
	    	String weather_title81=sPlit7[0].replace("白天", "");//第八天的白天的字段
	    	String weather_title82=sPlit7[1].replace("夜间", "");//第八天的夜晚的字段
            System.out.println(weather_title81);//第八天的白天天气情况
            System.out.println(weather_title82);//第八天的夜晚天气情况
	    	
	    	w5=sPlit2[2];
	    	String[] sPlit8=w5.split("~");
	    	String weather_temp81=sPlit8[0].replace("气温", "");
	    	String weather_temp82=sPlit8[1].replace("~", "").replace(",", "");
	    	System.out.println(weather_temp81);//第八天的最低气温
	    	System.out.println(weather_temp82);//第八天的最高气温
	    	
	    	w6=sPlit2[3];
	    	String[] sPlit9=w6.split(" ");
	    	String weather_winddirection81=sPlit9[0];
	    	String weather_windpower81=sPlit9[1];
	    	System.out.println(weather_winddirection81);//第八天的风向
	    	System.out.println(weather_windpower81);//第八天的风力
	    	
	    	
	    	String[] sPlit3=t3.split(" "); 
	    	int i3=t3.length();
	    	System.out.println(sPlit3[1]);
	    	System.out.println(sPlit3[2]);
	    	System.out.println(sPlit3[3]);
	    	
	    	String w7="";
	    	String w8="";
	    	String w9="";
	    	w7=sPlit3[1];
	    	String[] sPlit10=w7.split(",");
	    	String weather_title91=sPlit10[0].replace("白天", "");//第九天的白天的字段
	    	String weather_title92=sPlit10[1].replace("夜间", "");//第九天的夜晚的字段
            System.out.println(weather_title91);//第九天的白天天气情况
            System.out.println(weather_title92);//第九天的夜晚天气情况
	    	
	    	w8=sPlit3[2];
	    	String[] sPlit11=w8.split("~");
	    	String weather_temp91=sPlit11[0].replace("气温", "");
	    	String weather_temp92=sPlit11[1].replace("~", "").replace(",", "");
	    	System.out.println(weather_temp91);//第九天的最低气温
	    	System.out.println(weather_temp92);//第九天的最高气温
	    	
	    	w9=sPlit3[3];
	    	String[] sPlit12=w9.split(" ");
	    	String weather_winddirection91=sPlit12[0];
	    	String weather_windpower91=sPlit12[1].replace("<script", "");
	    	System.out.println(weather_winddirection91);//第九天的风向
	    	System.out.println(weather_windpower91);//第九天的风力
	    			
		} catch (MalformedURLException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		} finally {
			try {
				if (null != br) {
					br.close();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
			br = null;

			try {
				if (null != isr) {
					isr.close();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
			isr = null;

			try {
				if (null != in) {
					in.close();
				}
			} catch (IOException e) {
				e.printStackTrace();
			}
			in = null;
		}

	}
}

输出:

7天后安庆天气:&nbsp;白天阵雨,夜间阵雨,&nbsp;气温2℃~9℃,&nbsp;北偏东风 二级
8天后安庆天气:&nbsp;白天阵雨,夜间阵雨,&nbsp;气温-1℃~7℃,&nbsp;北偏东风 二级
9天后安庆天气:&nbsp;白天局部多云,夜间局部多云,&nbsp;气温-1℃~8℃,&nbsp;北偏东风 二级<script
白天阵雨,夜间阵雨,
气温2℃~9℃,
北偏东风 二级
阵雨
阵雨
2℃
9℃
北偏东风
二级
阵雨
阵雨
-1℃
7℃
北偏东风
二级
白天局部多云,夜间局部多云,
气温-1℃~8℃,
北偏东风 二级<script
局部多云
局部多云
-1℃
8℃
北偏东风
二级





















目录
相关文章
|
10月前
|
算法 PyTorch 算法框架/工具
昇腾 msmodelslim w8a8量化代码解析
msmodelslim w8a8量化算法原理和代码解析
854 5
|
搜索推荐 UED Python
实现一个带有昼夜背景切换的动态时钟:从代码到功能解析
本文介绍了一个使用Python和Tkinter库实现的动态时钟程序,具有昼夜背景切换、指针颜色随机变化及整点和半点报时功能。通过设置不同的背景颜色和随机变换指针颜色,增强视觉吸引力;利用多线程技术确保音频播放不影响主程序运行。该程序结合了Tkinter、Pygame、Pytz等库,提供了一个美观且实用的时间显示工具。欢迎点赞、关注、转发、收藏!
499 94
|
10月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
10月前
|
传感器 监控 Java
Java代码结构解析:类、方法、主函数(1分钟解剖室)
### Java代码结构简介 掌握Java代码结构如同拥有程序世界的建筑蓝图,类、方法和主函数构成“黄金三角”。类是独立的容器,承载成员变量和方法;方法实现特定功能,参数控制输入环境;主函数是程序入口。常见错误包括类名与文件名不匹配、忘记static修饰符和花括号未闭合。通过实战案例学习电商系统、游戏角色控制和物联网设备监控,理解类的作用、方法类型和主函数任务,避免典型错误,逐步提升编程能力。 **脑图速记法**:类如太空站,方法即舱段;main是发射台,static不能换;文件名对仗,括号要成双;参数是坐标,void不返航。
425 5
|
11月前
|
人工智能 文字识别 自然语言处理
保单AI识别技术及代码示例解析
车险保单包含基础信息、车辆信息、人员信息、保险条款及特别约定等关键内容。AI识别技术通过OCR、文档结构化解析和数据校验,实现对保单信息的精准提取。然而,版式多样性、信息复杂性、图像质量和法律术语解析是主要挑战。Python代码示例展示了如何使用PaddleOCR进行保单信息抽取,并提出了定制化训练、版式分析等优化方向。典型应用场景包括智能录入、快速核保、理赔自动化等。未来将向多模态融合、自适应学习和跨区域兼容性发展。
|
自然语言处理 搜索推荐 数据安全/隐私保护
鸿蒙登录页面好看的样式设计-HarmonyOS应用开发实战与ArkTS代码解析【HarmonyOS 5.0(Next)】
鸿蒙登录页面设计展示了 HarmonyOS 5.0(Next)的未来美学理念,结合科技与艺术,为用户带来视觉盛宴。该页面使用 ArkTS 开发,支持个性化定制和无缝智能设备连接。代码解析涵盖了声明式 UI、状态管理、事件处理及路由导航等关键概念,帮助开发者快速上手 HarmonyOS 应用开发。通过这段代码,开发者可以了解如何构建交互式界面并实现跨设备协同工作,推动智能生态的发展。
765 10
鸿蒙登录页面好看的样式设计-HarmonyOS应用开发实战与ArkTS代码解析【HarmonyOS 5.0(Next)】
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
3918 11
|
11月前
|
人工智能 算法 Ubuntu
动态规划篇】正则表达式与通配符:开启代码匹配的赛博奇幻之旅
动态规划篇】正则表达式与通配符:开启代码匹配的赛博奇幻之旅
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
200 20
|
机器学习/深度学习 存储 人工智能
强化学习与深度强化学习:深入解析与代码实现
本书《强化学习与深度强化学习:深入解析与代码实现》系统地介绍了强化学习的基本概念、经典算法及其在深度学习框架下的应用。从强化学习的基础理论出发,逐步深入到Q学习、SARSA等经典算法,再到DQN、Actor-Critic等深度强化学习方法,结合Python代码示例,帮助读者理解并实践这些先进的算法。书中还探讨了强化学习在无人驾驶、游戏AI等领域的应用及面临的挑战,为读者提供了丰富的理论知识和实战经验。
709 5

推荐镜像

更多
  • DNS