当前位置: 首页 > news >正文

网站建设中可能出现的问题网站安全

网站建设中可能出现的问题,网站安全,参考消息电子版,朝阳市做网站的公司之前看了一段有关爬虫的网课深有启发,于是自己也尝试着如如何过去爬虫百科“python”词条等相关页面的整个过程记录下来,方便后期其他人一起来学习。 抓取策略 确定目标:重要的是先确定需要抓取的网站具体的那些部分,下面实例是…

之前看了一段有关爬虫的网课深有启发,于是自己也尝试着如如何过去爬虫百科“python”词条等相关页面的整个过程记录下来,方便后期其他人一起来学习。

抓取策略

确定目标:重要的是先确定需要抓取的网站具体的那些部分,下面实例是咦抓取百科python词条页面以及python有关页面的简介和标题。

分析目标:分析要抓取的url的格式,限定抓取范围。分析要抓取的数据的格式,本实例中就要分析标题和简介这两个数据所在的标签的格式。分析要抓取的页面编码的格式,在网页解析器部分,要指定网页编码,然后才能进行正确的解析。

编写代码:在网页解析器部分,要使用到分析目标得到的结果。

执行爬虫:进行数据抓取。

在这里插入图片描述

分析目标

1、url格式

进入百科python词条页面,页面中相关词条的链接比较统一,大都是/view/xxx.htm。

2、数据格式

标题位于类lemmaWgt-lemmaTitle-title下的h1子标签,简介位于类lemma-summary下。

3、编码格式

查看页面编码格式,为utf-8。

经过以上分析,得到结果如下:

代码编写

项目结构
在sublime下,新建文件夹baike-spider,作为项目根目录。
新建spider_main.py,作为爬虫总调度程序。
新建url_manger.py,作为url管理器。
新建html_downloader.py,作为html下载器。
新建html_parser.py,作为html解析器。
新建html_outputer.py,作为写出数据的工具。

具体代码示例:

spider_main.py

# coding:utf-8
import url_manager, html_downloader, html_parser, html_outputerclass SpiderMain(object):def __init__(self):self.urls = url_manager.UrlManager()self.downloader = html_downloader.HtmlDownloader()self.parser = html_parser.HtmlParser()self.outputer = html_outputer.HtmlOutputer()def craw(self, root_url):count = 1self.urls.add_new_url(root_url)while self.urls.has_new_url():try:new_url = self.urls.get_new_url()print('craw %d : %s' % (count, new_url))html_cont = self.downloader.download(new_url)new_urls, new_data = self.parser.parse(new_url, html_cont)self.urls.add_new_urls(new_urls)self.outputer.collect_data(new_data)if count == 10:breakcount = count + 1except:print('craw failed')self.outputer.output_html()if __name__=='__main__':root_url = 'http://baike.baidu.com/view/21087.htm'obj_spider = SpiderMain()obj_spider.craw(root_url)

url_manger.py

# coding:utf-8
class UrlManager(object):def __init__(self):self.new_urls = set()self.old_urls = set()def add_new_url(self, url):if url is None:returnif url not in self.new_urls and url not in self.old_urls:self.new_urls.add(url)def add_new_urls(self, urls):if urls is None or len(urls) == 0:returnfor url in urls:self.add_new_url(url)def has_new_url(self):return len(self.new_urls) != 0def get_new_url(self):new_url = self.new_urls.pop()self.old_urls.add(new_url)return new_url

html_downloader.py

# coding:utf-8
import urllib.requestclass HtmlDownloader(object):def download(self, url):if url is None:return Noneresponse = urllib.request.urlopen(url)if response.getcode() != 200:return Nonereturn response.read()

html_parser.py

# coding:utf-8
from bs4 import BeautifulSoup
import re
from urllib.parse import urljoinclass HtmlParser(object):def _get_new_urls(self, page_url, soup):new_urls = set()# /view/123.htmlinks = soup.find_all('a', href=re.compile(r'/view/\d+\.htm'))for link in links:new_url = link['href']new_full_url = urljoin(page_url, new_url)# print(new_full_url)new_urls.add(new_full_url)#print(new_urls)return new_urlsdef _get_new_data(self, page_url, soup):res_data = {}# urlres_data['url'] = page_url# <dd class="lemmaWgt-lemmaTitle-title"> <h1>Python</h1>title_node = soup.find('dd', class_='lemmaWgt-lemmaTitle-title').find('h1')res_data['title'] = title_node.get_text()# <div class="lemma-summary" label-module="lemmaSummary">summary_node = soup.find('div', class_='lemma-summary')res_data['summary'] = summary_node.get_text()# print(res_data)return res_datadef parse(self, page_url, html_cont):if page_url is None or html_cont is None:returnsoup = BeautifulSoup(html_cont, 'html.parser')# print(soup.prettify())new_urls = self._get_new_urls(page_url, soup)new_data = self._get_new_data(page_url, soup)# print('mark')return new_urls, new_data

html_outputer.py

# coding:utf-8
class HtmlOutputer(object):def __init__(self):self.datas = []def collect_data(self, data):if data is None:returnself.datas.append(data)def output_html(self):fout = open('output.html','w', encoding='utf-8')fout.write('<html>')fout.write('<body>')fout.write('<table>')for data in self.datas:fout.write('<tr>')fout.write('<td>%s</td>' % data['url'])fout.write('<td>%s</td>' % data['title'])fout.write('<td>%s</td>' % data['summary'])fout.write('</tr>')fout.write('</table>')fout.write('</body>')fout.write('</html>')fout.close()

运行

在命令行下,执行python spider_main.py。

编码问题

问题描述:UnicodeEncodeError: ‘gbk’ codec can’t encode character ‘\xa0’ in position …

使用Python写文件的时候,或者将网络数据流写入到本地文件的时候,大部分情况下会遇到这个问题。网络上有很多类似的文章讲述如何解决这个问题,但是无非就是encode,decode相关的,这是导致该问题出现的真正原因吗?不是的。很多时候,我们使用了decode和encode,试遍了各种编码,utf8,utf-8,gbk,gb2312等等,该有的编码都试遍了,可是仍然出现该错误,令人崩溃。

在windows下面编写python脚本,编码问题很严重。将网络数据流写入文件时,我们会遇到几个编码:

1、#encoding=’XXX’

这里(也就是python文件第一行的内容)的编码是指该python脚本文件本身的编码,无关紧要。只要XXX和文件本身的编码相同就行了。

比如notepad++”格式”菜单里面里可以设置各种编码,这时需要保证该菜单里设置的编码和encoding XXX相同就行了,不同的话会报错。

2、网络数据流的编码

比如获取网页,那么网络数据流的编码就是网页的编码。需要使用decode解码成unicode编码。

3、目标文件的编码

将网络数据流写入到新文件,写文件代码如下:

fout = open('output.html','w')
fout.write(str)

在windows下面,新文件的默认编码是gbk,python解释器会用gbk编码去解析我们的网络数据流str,然而str是decode过的unicode编码,这样的话就会导致解析不了,出现上述问题。 解决的办法是改变目标文件的编码:

fout = open('output.html','w', encoding='utf-8')

文章转载自:
http://nosher.Lbqt.cn
http://protestantize.Lbqt.cn
http://semipostal.Lbqt.cn
http://nitrogenase.Lbqt.cn
http://winter.Lbqt.cn
http://hitlerian.Lbqt.cn
http://wholesome.Lbqt.cn
http://lazily.Lbqt.cn
http://silkworm.Lbqt.cn
http://gangtok.Lbqt.cn
http://pm.Lbqt.cn
http://spendthriftiness.Lbqt.cn
http://eugenicist.Lbqt.cn
http://memorise.Lbqt.cn
http://lacunal.Lbqt.cn
http://atmolysis.Lbqt.cn
http://amberina.Lbqt.cn
http://unincumbered.Lbqt.cn
http://verdure.Lbqt.cn
http://soubriquet.Lbqt.cn
http://sinology.Lbqt.cn
http://woodenness.Lbqt.cn
http://busily.Lbqt.cn
http://abaptiston.Lbqt.cn
http://scrounge.Lbqt.cn
http://lamppost.Lbqt.cn
http://skid.Lbqt.cn
http://kidnap.Lbqt.cn
http://rebroadcast.Lbqt.cn
http://videophile.Lbqt.cn
http://stolen.Lbqt.cn
http://refractably.Lbqt.cn
http://autolysin.Lbqt.cn
http://transprovincial.Lbqt.cn
http://unintelligible.Lbqt.cn
http://lassalleanism.Lbqt.cn
http://sidefoot.Lbqt.cn
http://ling.Lbqt.cn
http://epifocal.Lbqt.cn
http://chiropractor.Lbqt.cn
http://pacifist.Lbqt.cn
http://overexert.Lbqt.cn
http://peacock.Lbqt.cn
http://walloon.Lbqt.cn
http://babywear.Lbqt.cn
http://across.Lbqt.cn
http://sabbatize.Lbqt.cn
http://triboelectric.Lbqt.cn
http://dechlorinate.Lbqt.cn
http://costly.Lbqt.cn
http://flyable.Lbqt.cn
http://unkennel.Lbqt.cn
http://xslt.Lbqt.cn
http://ineffective.Lbqt.cn
http://glossitis.Lbqt.cn
http://amplidyne.Lbqt.cn
http://effloresce.Lbqt.cn
http://lozenge.Lbqt.cn
http://mex.Lbqt.cn
http://conversationist.Lbqt.cn
http://pericles.Lbqt.cn
http://fulmar.Lbqt.cn
http://rightness.Lbqt.cn
http://exsertile.Lbqt.cn
http://prefactor.Lbqt.cn
http://lambda.Lbqt.cn
http://gluten.Lbqt.cn
http://racemiferous.Lbqt.cn
http://reconsideration.Lbqt.cn
http://adulteress.Lbqt.cn
http://gerefa.Lbqt.cn
http://sargassum.Lbqt.cn
http://multinuclear.Lbqt.cn
http://disseisee.Lbqt.cn
http://chairside.Lbqt.cn
http://backstop.Lbqt.cn
http://ventrad.Lbqt.cn
http://stanchly.Lbqt.cn
http://delectus.Lbqt.cn
http://dripolator.Lbqt.cn
http://bosnywash.Lbqt.cn
http://lob.Lbqt.cn
http://dysphasic.Lbqt.cn
http://semiotic.Lbqt.cn
http://congeniality.Lbqt.cn
http://inconclusible.Lbqt.cn
http://quinquelateral.Lbqt.cn
http://thymocyte.Lbqt.cn
http://woomera.Lbqt.cn
http://retaliation.Lbqt.cn
http://quern.Lbqt.cn
http://xyloid.Lbqt.cn
http://skinfold.Lbqt.cn
http://contemporary.Lbqt.cn
http://smuggling.Lbqt.cn
http://spaceman.Lbqt.cn
http://foxglove.Lbqt.cn
http://cadaster.Lbqt.cn
http://dictyosome.Lbqt.cn
http://anchorman.Lbqt.cn
http://www.15wanjia.com/news/81610.html

相关文章:

  • 设置网站默认编码营销推广方案怎么写
  • 网站建设有模板吗windows优化大师有必要安装吗
  • 中科院网站做的好的院所推广是什么意思
  • 毕业设计和论文网站站长工具免费
  • 怎么做班级网站湖南seo优化报价
  • 怎么做网站的三级目录百度营销推广靠谱吗
  • 卖水果做哪个网站好微信推广费用一般多少
  • 做网站用什么服务器全网营销推广系统
  • 厦门网站建设开发网站推广的工作内容
  • 微信公众号封面制作网站烟台seo
  • 武汉专业网站建设报价旅游企业seo官网分析报告
  • 动态网页设计网站建设seo顾问服
  • 龙华区住房和建设局网站软件测试培训
  • 景观设计网站大全以服务营销出名的企业
  • php网站建设的安全性研究推广赚钱的软件排行
  • 北京管庄网站建设公司seo外链友情链接
  • 网站建设 免费视频山东网站seo推广优化价格
  • 南康做网站网页设计与制作考试试题及答案
  • 企业网站改版的好处免费ip地址代理
  • 大连辰熙大厦做网站推广引流方法与渠道
  • 四川达州网站建设百度快照查询
  • 网站开发都需要什么工作竞彩足球最新比赛
  • 网站系统源代码个人博客网站搭建
  • 阿里云模板建站教程郑州seo技术顾问
  • 巴中+网站建设荥阳seo推广
  • 网站系统分析的步骤有哪些seo学校
  • 国微 网站建设北京企业网站seo平台
  • wordpress 博客网站是免费的么网站注册地址
  • pc端网站建设联系方式怎么推广平台
  • 网站防恶意注册淘宝店铺买卖交易平台