按照上次python 学习(二)的思路,第一步要实现从一个网站的页面上自动获取指定列表中的信息。折腾数日,得到一段可以正常运行的代码,如下:

 #web2.py

 import re
import urllib.request def get_msg_for_url(s): if s =='':
print("not url!\n")
exit() ah_whdeps_url = {"ahswht":"http://www.ahwh.gov.cn/"} msg_from={"ahswht":"http://www.ahwh.gov.cn/zz/shwhc/gzdt5/"}
msg_re={"ahswht1":r'<div class="title"><a href="(.*)" title="(.*)" target="_blank">',
"ahswht2":r'<div class="time">\[(.*)\]</div>' } getTotalPageRe =r'共(.*)条 当前第(.*) 页</div>' res_url = 'aspx/doView.aspx?siteid=52&contentid=0&channelId=432&pchannelid=399&templateType=2&Page='
response=urllib.request.urlopen(msg_from[s])
html = response.read().decode("gbk") # 针对带汉字的网页进行解码 gtpr = re.findall(getTotalPageRe, html) # 获取信息总条数和页数
msg_totle = int(gtpr[0][0].strip()) # get the numbers of message
page_totle = int(gtpr[0][1].split('/')[1].strip()) # get the numbers of page m = 1 filename = s+'.txt'
f = open(filename,"w") for n in range(1, page_totle+1):
response = urllib.request.urlopen(ah_whdeps_url["ahswht"]+res_url+str(n))
html = response.read().decode('utf-8','ignore') gt = re.findall(msg_re[s+''], html) #抽取url页面中新闻的标题、网址 gd = re.findall(msg_re[s+''], html) #抽取url页面中的发布时间 for i in range(0,len(gt),1):
try:
f.write('%d\n%s\n%s\n%s\n'%(m,ah_whdeps_url[s]+gt[i][0][1:], gt[i][1], gd[i]))
m += 1
except UnicodeEncodeError as e:
pass print("There are %d messages to be saved!"%(m-1))
f.close() def main():
get_msg_for_url("ahswht") if __name__=="__main__":
main()

代码功能说明:第12行,定义指定网站;第14行定义指定网页。第15行定义抽取信息的正则表达式,这里是获取每条信息的标题及网址,如下图。第16行,定义抽取每条信息发布时间的正则表达式。

15     msg_re={"ahswht1":r'<div class="title"><a href="(.*)" title="(.*)" target="_blank">',
16 "ahswht2":r'<div class="time">\[(.*)\]</div>' }

第18-26行:获取这个列表所有信息的条数以及页面数。方法是通过分析页上的一个特定字符串:“共?条 当前第?页”。第25行得到信息总条数,第26行得到页面数。

第30-40行:获取该列表下所有信息,并以[行号\n链接\n标题\n发布时间\n]的形式,保存到一个文本文件(如下图)中。

个人难点:写这段代码花费时间最长的地方是第35行,即网页上字符的编码与解码问题。现在是权宜之计,直接无视,即一旦发现某个标题行的字符串解码不出来,就跳到下一个标题上去,而不是让程序中断。html = response.read().decode('utf-8','ignore')  我们的口号是:“先让程序动起来,再让它跑得快!”

——————————————————————

既然这段代码可以实现原来设想的功能,下一步的事情就是在这段代码的基础上进行启动了。 

下面的第一步,可以将指定页面的正则表达式独立出来,不在程序中硬编码,而是保存在另外一个独立的文本文件。这样的话,如果要获取另外一个网站指定栏目下面的信息,只需要在文本文件中添加相应的规则即可,不必再重要写代码。

如此一来,整个项目就比较清楚地划分为三个部分:一是输入文件;二是处理模块;三是输出文件。其中,输入文件定义获取信息的规则,处理模块负责从输入文件中读取信息提取规则,按照规则获取相关信息,再将获得的信息按固定格式,存入指定输出文件;输出文件保存信息。

python 学习(三)的更多相关文章

  1. Python学习三---序列、列表、元组

    一.序列 1.1.序列概念 pythn中最基本的数据结构是序列(sequence). 序列中每个元素被分配一个序号-元素索引,第一个索引是0,第二个是1,以此类推.类似JAVA中数组和集合中的下标. ...

  2. python学习 (三十三) Modules

    1: 方法一: 导入整个模块 import math class ModulesDemo(): def builtin_modules(self): print(math.sqrt()) m = Mo ...

  3. Python学习三天计划-1

    一.第一个Python程序 配置好环境变量后 打开CMD(命令提示符)程序,输入Python并回车 然后,在里面输入代码回车即可立即执行 Python解释器的作用是 将Python代码翻译成计算机认识 ...

  4. Python学习三天计划-3

    面向对象 一.类的定义 1.类定义 class是关键字,表示要定义类了 类的属性,即定义在类中的变量(成员变量) 类的行为,即定义在类中的函数(成员方法) 2.对象 创建类对象的语法: class S ...

  5. Python学习(三) 输出任意格式的字符串以及字符串的切片

    在Python中想要输出一句话,如下 a='hello world' print a //打印出的是hello world print 'hello \n world' //打印出的是 //hello ...

  6. Python学习(三):迭代器、生成器、装饰器、递归、算法、正则

    1.迭代器 迭代器是访问集合的一种方式,迭代对象从集合的第一个元素开始访问,直到元素被访问结束,迭代器只能往前不能后退,最大的优点是不要求事先准备好整个迭代过程中的元素,这个特点使得它特别适合用于遍历 ...

  7. python 学习三

    list循环删除下标会出错 L = [1,1,1,2,3,4,5]#list是根据下标来取值 #下标0,1,2,3,4,5,6 循环后下标错位 输出的结果是[1,2,4],把1也取到了 #l2 = [ ...

  8. Python学习三|列表、字典、元组、集合的特点以及类的一些定义

    此表借鉴于他人 定义 使用方法 列表 可以包含不同类型的对象,可以增减元素,可以跟其他的列表结合或者把一个列表拆分,用[]来定义的 eg:aList=[123,'abc',4.56,['inner', ...

  9. python学习 (三十一) python中的class

    1 python的类:   Python类都继承自object. __init__: 构造函数,如果不写,有一个默认的. __init__: 这个构造函数只能有一个,Python中不能有多个构造函数. ...

  10. python学习三(数据保存到文件)

    以写模式打开文件:需要指定写模式,如下所示 data = open('data.out','w') 如果文件已经存在,则会清空它现有的所有内容.要追加一个文件,需要使用访问模式a,会追加到下一行. 例 ...

随机推荐

  1. (转载)MVC 4.0 PartialView()与View()真的一样吗?

    转载自:http://www.cnblogs.com/lori/ 当我们使用razor作为页面引擎时,它的视图文件扩展名为cshtml或者vbshtml,而之前作为分部视图的ascx文件,进行razo ...

  2. 命令提示符CMD远程连接Mysql学习笔记

    我想要用Cmd可以像SecureCRT一样远程连接数据库,查询数据,因为用cmd的话可以用批处理,方便脚本调用 第一步:直接使用命令 mysql –h ip –u user –p,本地运行了该命令提示 ...

  3. ASIHTTPRequest中的DELETE、PUT、GET、POST请求实例-备用

    感谢分享 //  ASIFormDataRequestTests.m //  Part of ASIHTTPRequest -> http://allseeing-i.com/ASIHTTPRe ...

  4. Android中半透明Activity效果另法

    Android中的Activity有没有类似于像Windows程序样的窗口式显示呢? 答案当然是有. 下图就是一个窗口式Activity的效果图: 下面就说说实现过程: 首先看看AndroidMani ...

  5. FJ省队集训DAY4 T3

    #include<cstdio> #include<iostream> #include<cmath> #include<cstring> #inclu ...

  6. IIS Express 的 applicationhost.config配置文件

    文件所在目录 C:\Users\admin\Documents\IISExpress\config 或者 C:\Program Files\IIS Express\AppServer\ //加载语言文 ...

  7. CoreData Multiple Context性能分析-读书笔记

    From: http://floriankugler.com/blog/2013/4/29/concurrent-core-data-stack-performance-shootout  http: ...

  8. 什么是空间复杂度(What is actually Space Complexity ?)

    属于空间复杂度(Space Complexity)在很多情况下被错认为是附属空间(Auxiliary Space),下面是附属空间和空间复杂度的定义. 附属空间(Auxiliary Space)是算法 ...

  9. [置顶] API相关工作过往的总结之Sandcastle简要使用介绍

    Sandcastle介绍 在微软推出Sandcastle之前,人们倾向于选择开源的NDoc(.NET代码文档生成器).NDo可以将 C#.NET 编译生成的程序集和对应的 /doc XML文档,自动转 ...

  10. AJAX上传文件

    function up_files() { var fileSelect = document.getElementById('file-select'); var files = fileSelec ...