python爬虫04

不多说了,上代码,看注释吧,写的够详细了

# encoding: utf-8
#加载bs4、urllib2
from bs4 import BeautifulSoup
import urllib2
import codecs
import re
import sys
import types

#定义一个方法,方法的作用提交url并获取到到此url的html页面源码
def header (url):
    user_agent = 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.101 Safari/537.36'
    header = {'User-Agent':'user_agent'}
    #把url、header穿过去
    re = urllib2.Request(url,headers=header)
    respone = urllib2.urlopen(re,'html.parser')
    #获取html代码,保存到htmlcode,一个字符串
    htmlcode = respone.read()
    return htmlcode
#定义一个把爬取到的内容,写入到文本的方法
def file_save(file_name,text):
    #由于开始文本是不存在的,所以使用w,进行检查如果不存在就创建,如果是r,那么就是追加
    f = open(file_name,'w')
    #把list写入到file_name里面,并且list进行换行,注意的是用join,据说效率比+ 高
    f.write('\n'.join(text))
    #关闭文件
    f.close()
#定义一个方法,接受三个参数、url、开始也、结束页
def load_url(url,begin_page,end_page):
    #加载这个,是解决utf8的问题
    reload(sys)
    sys.setdefaultencoding('utf8')
    #拼接url,重点重点,搞了好长时间
    for i in range(begin_page,end_page+1):
        zcurl = url + str(i)
        zc_html_code = header(zcurl)
        #这里是一个列表了
        st = st_html(zc_html_code)
        print st
        file_name = str(i) + '.txt'
        file_save(file_name,st)
#定义爬取规则的方法
def st_html(text):
    soup = BeautifulSoup(text,'html.parser')
    #这段代码的意思,先用find查找第一个table,然后在table里面查找target
    find_html = soup.find('table','table_body').find_all(attrs={'target':'_blank'})
    #find_html = soup.find_all(attrs={'target':'_blank'}).string
    #因为要return回去,所以先创建一个空的列表
    list = []
    for i in find_html:
        #注意。.get_text获取文本,如果获取url,参照上一篇的文章,i['herf]
        a = i.get_text()
        list.append(a)
    #返回列表,load_url要调用
    return list



url = 'https://www.chinabidding.cn/search/searchzbw/search2?rp=22&categoryid=1&keywords=轨道交通&page='
begin_page = input("请输入开始页的id:")
end_page = input("请输入结束页的id:")
load_url(url,begin_page,end_page)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

m0_37204377

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值