python爬取返利网商品信息

python爬取返利网商品信息,第1张

概述python爬取返利商品信息

下面是内存溢出 jb51.cc 通过网络收集整理的代码片段。

内存溢出小编现在分享给大家,也给大家做个参考。

#Coding=utf-8import sysreload(sys)sys.setdefaultencoding( "utf-8" )import urllib2import refrom bs4 import BeautifulSoupimport timeimport socket#返利网ip为fanly_urlfanly_path="F:\yaozhi\yaozhi.txt"fanly_url="http://zhIDe.fanli.com/p"format_url="http://zhIDe.fanli.com/detail/1-"reg=r'data-ID="\d{6}"'reg2=r"\d{6}"reg3='"lowest-network"'reg4=r'<.+?>'result=re.compile(reg)class faly():    def __init__(self):        #初始化头文件  'User-Agent'        self.user_agent='Mozilla/5.0 (windows NT 6.1; WOW64; rv:41.0) Gecko/20100101 firefox/41.0'        self.HTML_data=[]    def get_HTML(self,start_page=1,end_page=7):        if start_page<1:            return "页码输入错误"        elif end_page>1000:            return "页码超出范围,请输入1-100的整数!"        for i in range(start_page,end_page+1):            print("----正在采集%d页的数据----"%i)            rt=urllib2.Request(fanly_url+str(i))            rt.add_header( 'User-Agent',self.user_agent)#网络连接可能会出现问题,存在ip被封的风险,得到需要采集的网页的HTML            try:                my_data = urllib2.urlopen(rt).read()                self.HTML_data.append(my_data)                time.sleep(2)                socket.setdefaulttimeout(15)            except urllib2.URLError,e:                if hasattr(e,'reason'):                    print u"连接失败",e.reason        return  str(self.HTML_data)#print(faly().get_HTML())class GetData():    def __init__(self):        self.HTML=faly().get_HTML()        self.href=[]        self.ls=[]        self.url=[]#通过获取href的值,得到实际需要访问的网址,网址变化的只是后面的数字,用正则表达式匹配,然后进行去重    def get_hrefurl(self):        tag=result.findall(self.HTML)        for i in tag:            self.href.append(i)        result2=re.findall(reg2,str(self.href))        if len(result2):            for data in result2:                if data not in self.ls:                    self.ls.append(data)                    url=format_url+str(data)                    self.url.append(url)        return self.url#print GetData().get_hrefurl()#获取商品的具体信息,包括打折商品网站、商品价格、简介等信息class href_mg():    def __init__(self):        self.List=GetData().get_hrefurl()        self.txt_List=[]    def show_mg(self):        for item in range(len(self.List)):            if len(self.List):                url=str(self.List[item])                mg=urllib2.Request(url)                try:                    req=urllib2.urlopen(mg).read()                    soup=BeautifulSoup(req,"HTML.parser")                    txt=soup.find_all('h1')                    self.txt_List.append(txt)                except urllib2.URLError,e:                    print e.reason        return str(self.txt_List).decode("unicode_escape")#print  href_mg().show_mg()if __name__ == "__main__":#提取文档,规整数据,写入本地    with open(fanly_path,'a') as file:        data=href_mg().show_mg()        data_s=re.sub(reg4,' ',data).replace('全网最低','').replace('[','').replace(']','').replace(',','\n').strip().replace('  ','')        file.write(str(data_s))

以上是内存溢出(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

总结

以上是内存溢出为你收集整理的python爬取返利网商品信息全部内容,希望文章能够帮你解决python爬取返利网商品信息所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1199329.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-04
下一篇 2022-06-04

发表评论

登录后才能评论

评论列表(0条)

保存