亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Python > 正文

python爬取網頁內容轉換為PDF文件

2020-02-15 21:41:25
字體:
來源:轉載
供稿:網友

本文實例為大家分享了python爬取網頁內容轉換為PDF的具體代碼,供大家參考,具體內容如下

將廖雪峰的學習教程轉換成PDF文件,代碼只適合該網站,如果需要其他網站的教程,可靠需要進行稍微的修改。

# coding=utf-8 import os import re import time import pdfkit import requests from bs4 import BeautifulSoup from PyPDF2 import PdfFileMergerimport sysreload(sys)sys.setdefaultencoding('utf8')html_template = """ <!DOCTYPE html> <html lang="en"> <head>   <meta charset="UTF-8"> </head> <body> {content} </body> </html> """ #----------------------------------------------------------------------def parse_url_to_html(url, name):   """   解析URL,返回HTML內容   :param url:解析的url   :param name: 保存的html文件名   :return: html   """   try:     response = requests.get(url)     soup = BeautifulSoup(response.content, 'html.parser')     # 正文     body = soup.find_all(class_="x-wiki-content")[0]     # 標題     title = soup.find('h4').get_text()     # 標題加入到正文的最前面,居中顯示     center_tag = soup.new_tag("center")     title_tag = soup.new_tag('h1')     title_tag.string = title     center_tag.insert(1, title_tag)     body.insert(1, center_tag)     html = str(body)     # body中的img標簽的src相對路徑的改成絕對路徑     pattern = "(<img .*?src=/")(.*?)(/")"     def func(m):       if not m.group(3).startswith("http"):         rtn = m.group(1) + "http://www.liaoxuefeng.com" + m.group(2) + m.group(3)         return rtn       else:         return m.group(1)+m.group(2)+m.group(3)     html = re.compile(pattern).sub(func, html)     html = html_template.format(content=html)     html = html.encode("utf-8")     with open(name, 'wb') as f:       f.write(html)     return name   except Exception as e:    print "解析錯誤!"#----------------------------------------------------------------------def get_url_list():   """   獲取所有URL目錄列表   :return:   """   response = requests.get("http://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000")   soup = BeautifulSoup(response.content, "html.parser")   menu_tag = soup.find_all(class_="uk-nav uk-nav-side")[1]   urls = []   for li in menu_tag.find_all("li"):     url = "http://www.liaoxuefeng.com" + li.a.get('href')     urls.append(url)   return urls #----------------------------------------------------------------------def save_pdf(htmls, file_name):   """   把所有html文件保存到pdf文件   :param htmls: html文件列表   :param file_name: pdf文件名   :return:   """   options = {     'page-size': 'Letter',     'margin-top': '0.75in',     'margin-right': '0.75in',     'margin-bottom': '0.75in',     'margin-left': '0.75in',     'encoding': "UTF-8",     'custom-header': [       ('Accept-Encoding', 'gzip')     ],     'cookie': [       ('cookie-name1', 'cookie-value1'),       ('cookie-name2', 'cookie-value2'),     ],     'outline-depth': 10,   }   pdfkit.from_file(htmls, file_name, options=options) #----------------------------------------------------------------------def main():   start = time.time()   file_name = u"liaoxuefeng_Python3_tutorial"   urls = get_url_list()   for index, url in enumerate(urls):    parse_url_to_html(url, str(index) + ".html")   htmls =[]   pdfs =[]   for i in range(0,124):     htmls.append(str(i)+'.html')     pdfs.append(file_name+str(i)+'.pdf')     save_pdf(str(i)+'.html', file_name+str(i)+'.pdf')     print u"轉換完成第"+str(i)+'個html'   merger = PdfFileMerger()   for pdf in pdfs:    merger.append(open(pdf,'rb'))    print u"合并完成第"+str(i)+'個pdf'+pdf   output = open(u"廖雪峰Python_all.pdf", "wb")   merger.write(output)   print u"輸出PDF成功!"   for html in htmls:     os.remove(html)     print u"刪除臨時文件"+html   for pdf in pdfs:     os.remove(pdf)     print u"刪除臨時文件"+pdf   total_time = time.time() - start   print(u"總共耗時:%f 秒" % total_time)#----------------------------------------------------------------------def changeDir(dir_name):  """  目錄切換  """  if not os.path.exists(dir_name):    os.mkdir(dir_name)  os.chdir(dir_name)#----------------------------------------------------------------------if __name__ == '__main__':  #存放文件的路徑  dir_name = '/home/Python/Html'    changeDir(dir_name)  main()             
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人精品久久久| 日韩国产高清污视频在线观看| 国产精品青草久久久久福利99| 国产一区二区三区精品久久久| 伊人久久久久久久久久久久久| 国产91精品不卡视频| 国产99视频精品免视看7| 欧美在线视频一区二区| 精品偷拍各种wc美女嘘嘘| 亚洲18私人小影院| 国产亚洲欧洲高清一区| 96精品久久久久中文字幕| 欧美激情免费观看| 久久精品夜夜夜夜夜久久| 日韩激情在线视频| 国产成人综合亚洲| 亚洲国产成人爱av在线播放| 国产精品成人免费电影| 国产精品日韩在线| 亚洲aⅴ日韩av电影在线观看| 国产成人免费91av在线| 欧美高清激情视频| 久久亚洲精品中文字幕冲田杏梨| 国产精品午夜国产小视频| 日韩的一区二区| 成人免费大片黄在线播放| 成人性生交大片免费观看嘿嘿视频| 色婷婷av一区二区三区在线观看| 国产精品电影观看| 日韩中文综合网| 欧美一区二区大胆人体摄影专业网站| 国产自产女人91一区在线观看| 91精品国产色综合久久不卡98| 久久久精品国产网站| 欧美重口另类videos人妖| 欧美一级免费视频| 久热精品视频在线观看一区| 神马国产精品影院av| 大桥未久av一区二区三区| 欧美日韩国产精品一区二区不卡中文| 久久91精品国产91久久跳| 国产成人在线视频| 最好看的2019的中文字幕视频| 国产一区二区丝袜| 欧美激情视频播放| 久久久久久久久久久人体| 中文字幕日韩在线观看| 欧美日韩另类视频| 国产成人一区二区| 色综久久综合桃花网| 久久综合久久美利坚合众国| 欧美大全免费观看电视剧大泉洋| 亚洲图片欧洲图片av| 久久这里只有精品视频首页| 97超碰蝌蚪网人人做人人爽| 国产成人激情视频| 欧美一级黄色网| 国语对白做受69| 亚洲一区二区久久| 亚洲另类欧美自拍| 国产日韩精品一区二区| 亚洲精品白浆高清久久久久久| 国产一区二区三区在线播放免费观看| 国产日韩中文字幕| 成人中心免费视频| 精品成人久久av| 亚洲精品少妇网址| 久久国产精品久久久久| 国产精品免费一区二区三区都可以| 最近2019好看的中文字幕免费| 精品国产区一区二区三区在线观看| 欧美精品免费在线观看| 狠狠综合久久av一区二区小说| 亚洲色图第一页| 日韩电影在线观看永久视频免费网站| 免费97视频在线精品国自产拍| 日韩av综合网| 亚洲精品ady| 色偷偷av亚洲男人的天堂| 亚洲视频专区在线| 日韩av在线网| 三级精品视频久久久久| 久久久精品电影| 国产欧美一区二区白浆黑人| 成人在线观看视频网站| 国产精品h片在线播放| 国产精品视频99| 中文字幕在线看视频国产欧美在线看完整| 91在线中文字幕| 日韩美女视频在线观看| 国产欧美日韩综合精品| 欧美日韩不卡合集视频| 精品二区三区线观看| 欧美日韩在线观看视频| 久久人人爽人人爽人人片av高请| 国产在线高清精品| 91社区国产高清| 午夜精品一区二区三区视频免费看| 日韩精品在线观看一区| 国产精品免费一区二区三区都可以| 国产亚洲精品美女久久久| 精品国产福利视频| 国产精品丝袜白浆摸在线| 欧美日韩国产中文精品字幕自在自线| 国产精品男人的天堂| 亚洲色图在线观看| 日韩av免费网站| 国产91热爆ts人妖在线| 亚洲欧美制服丝袜| 亚洲偷熟乱区亚洲香蕉av| 国产精品久久久久久av福利软件| 欧美性少妇18aaaa视频| 欧美日韩免费看| 久久精品美女视频网站| 亚洲白虎美女被爆操| 亚洲视频在线看| 日韩美女主播视频| 日韩一二三在线视频播| 久久成人国产精品| 日韩免费看的电影电视剧大全| 亚洲最大的免费| 国产欧美精品xxxx另类| 亚洲欧美精品一区| 亚洲影院色无极综合| 欧美二区乱c黑人| 亚洲精品午夜精品| 国产成人精品在线播放| 国产精品久久久久久久9999| 日韩电影视频免费| 91国产视频在线播放| 亚洲色图50p| 亚洲精品久久久一区二区三区| 色偷偷88888欧美精品久久久| 精品久久久免费| 欧美乱大交做爰xxxⅹ性3| 日韩美女av在线免费观看| 欧洲亚洲在线视频| 国产一区视频在线| 国产91色在线|免| 国产精品一区二区三区免费视频| 日韩专区中文字幕| 亚洲欧美国产高清va在线播| 亚洲精品欧美日韩专区| 免费99精品国产自在在线| 91精品国产综合久久香蕉| 欧美在线www| 人九九综合九九宗合| 精品国产视频在线| 国产亚洲精品久久久优势| 欧美成人亚洲成人日韩成人| 日日狠狠久久偷偷四色综合免费| 青青久久av北条麻妃海外网| 中文字幕欧美在线| 亚洲最大福利视频网站| 日韩亚洲在线观看| 自拍亚洲一区欧美另类| 欧洲成人在线观看| 国产日本欧美在线观看| 国产欧美日韩中文字幕在线| 91精品国产乱码久久久久久久久| 国产视频精品久久久| 国产一区二区三区精品久久久| 亚洲欧洲在线免费| 97超视频免费观看|