作为初学爬虫的我,无论是爬取文字还是图片,都可以游刃有余的做到,但是爬虫所爬取的内容往往不是单独的图片或者文字,于是我就想是否可以将图文保存至world文档里,一开始使用了如下方法保存图片:
with open('123.doc','wb')as file: file.write(response.content) file.close()
结果就是,world文档里出现了一堆乱码,此法不同,我就开始另寻他法,找了很久也没有找到,只找到了关于Python操作world的方法。
于是我就开始了新的思路:使用原来的方法将图片保存下来,再将图片添加到world文档里,最后将图片删除。这里使用的是python-dox库,代码如下:
import requestsfrom bs4 import BeautifulSoupimport osimport docxfrom docx import Documentfrom docx.shared import Inchesurl = 'https://www.qiushibaike.com/article/119757360'html = requests.get(url).contentsoup = BeautifulSoup(html,'html.parser')wen = soup.find('div',{"class":"content"}).textimg = str(soup.find('div',{"class":"thumb"})).split('src="')[1].split('"/')[0]tu = 'https:' + imgimg_name = img.split('/')[-1]#保存图片至本地with open(img_name,'wb')as f: response = requests.get(tu).content f.write(response) f.close()document = Document()document.add_paragraph(wen)#向文档里添加文字document.add_picture(img_name)#向文档里添加图片document.save('tuwen.doc')#保存文档os.remove(img_name)#删除保存在本地的图片
最后,还是实现了将图文保存在了world文档里,尽管方法有些笨……
以上这篇Python爬虫将爬取的图片写入world文档的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持武林站长站。
新闻热点
疑难解答