【Python3 爬虫学习笔记】用Python进行Word文件操作

用Win32com组件操作Word文件

Python语言可通过Win32com组件对Microsoft Office文件进行存取,而且Python已内置了Win32com组件,不需要另外安装。
要用Win32com组件操作Microsoft Office文件,计算机必须已确保安装了Microsoft Office软件。

实现新建文件并保存

Win32com组件不需要安装,直接导入就可使用,下面我们先导入Win32com组件的client模块:

from win32com import client

要处理Word文件,需先创建Word应用程序变量。语法为:

应用变量 = client.gencache.EnsureDispatch('Word.Application')

例如,建立一个名为word的Word应用程序变量:

word = client.gencache.EnsureDispatch('Word.Application')

Word应用程序变量的Visible、DisplayAlerts属性及Documents方法:

  • Visible:1表示要显示Word界面,0表示不显示Word界面。
  • DisplayAlerts:1表示要显示Word警告信息,0表示不显示Word警告信息。
  • Documents:操作Word文件,如打开文件、保存文件等。
新建文件

用Win32com组件新建文件是通过Documents的Add()方法来实现,语法为:

文件变量 = 应用变量.Documents.Add()

例如,新建一个文件,并保存至变量doc:

doc = word.Documents.Add()

文件内容的位置可通过文件变量的Range()方法来设置,语法为:

范围变量 = 文件变量.Range(起始位置, 结束位置)

起始位置及结束位置为整数,表示字符的起始及结束位置。例如,把文件前10个字符保存至range1变量:

range1 = doc.Range(0, 9)

向Word文件中插入文本可通过两种方法来实现。一种方法是通过InsertAfter()方法,此方法把文字插入到范围变量结束位置之后,执行插入操作以后,位置变量的结束值会变为所插入的内容后的位置值,语法为:

范围变量.InsertAfter(文字)

另一种方法是通过InsetBefore()方法,此方法是将文字插入到范围变量起始位置的前面,语法为:

范围变量.InsertBefore(文字)

使用InsertBefore()方法插入文本后不会改变范围变量的起位置起始值,再次使用InsertBefore方法时,还是会把文字插入到变量最初起始位置值之前。

保存文件

本案例的Word文件位于media文件夹中(media文件夹与.py文件位于同一目录中)。由于Win32com组件存取文件时不能使用相对路径,所以必须先取得Python程序文件所在路径(即media文件夹的路径),语法为:

import os
路径变量 = os.path.dirname(__file__)

保存Word文件的语法为:

文件变量.SaveAd(路径变量)

例如,把文件保存在media文件夹中,文件名为test1.docx:

cpath = os.path.dirname(__file__)
doc.SaveAs(cpath + "\\media\\test1.docx")

处理完Word文件,通常会在程序最后关闭Word文件及应用,以免占用系统资源,语法为:

文件变量.Close()
应用变量.Quit()
实战:新建Word文件并存盘

用Win32com组件新建Word文件,插入内容后存盘。

import os
from win32com import client
word = client.gencache.EnsureDispatch('Word.Application')
word.Visible = 1
word.DisplayAlerts = 0
doc = word.Documents.Add()
range1 = doc.Range(0, 0)   # 设置范围变量的起止位置
range1.InsertAfter("这是测试第一行\n这是测试第二行\n")
range1.InsertAfter("这是测试第三行\n这是测试第四行\n")
range1.InsertBefore("第一次插入到文件最前方\n")
range1.InsertBefore("再次插入到文件最前方\n")
cpath = os.path.dirname(__file__)
doc.SaveAs(cpath + "\\media\\test1.docx")
# doc.Close()
# doc.Quit()
打开文件并显示文件内容

Win32com组件是通过Documents的Open()方法来实现打开文件的,语法为:

文件变量 = 应用变量.Documents.Open(文件路径)

例如,打开刚才保存的test1.docx文件,文件变量名为doc:

doc = word.Documents.Open(cpath + "\\media\\test1.docx")

获取文件内容的方法有两种,第一种较为简单,用文件变量的Content属性即可获取全部内容,语法为:

文件变量.Content

例如,通过下面代码可在命令窗口中显示doc文件变量的内容:

print(doc.Content)

第二种获取文件内容的方法是先取得所有段落,在通过循环来显示段落内容。取得所有段落的语法为:

段落集合变量 = 文件变量.Paragraphs

例如,取得所有段落内容并保存在paragraphs集合变量中:

paragraphs = doc.Paragraphs

通过循环显示段落内容的代码为:

for p in paragraphs:
    text = p.Range.Text.strip()
    print(text)

其中,"p.Range.Text"代码用于实现段落内容的读取,其后的strip()方法用于实现换行符的删除,执行结果与第一种方法相同。

python爬虫与项目实战,网络爬虫是一个自动提取网页的程序,它为搜索引擎从万维网上下载网页,是搜索引擎的重要组成。 随着网络的迅速发展,万维网成为大量信息的载体,如何有效地提取并利用这些信息成为一个巨大的挑战。搜索引擎(Search Engine),例如传统的通用搜索引擎AltaVista,Yahoo!和Google等,作为一个辅助人们检索信息的工具成为用户访问万维网的入口和指南。但是,这些通用性搜索引擎也存在着一定的局限性,如: (1)不同领域、不同背景的用户往往具有不同的检索目的和需求,通用搜索引擎所返回的结果包含大量用户不关心的网页。 (2)通用搜索引擎的目标是尽可能大的网络覆盖率,有限的搜索引擎服务器资源与无限的网络数据资源之间的矛盾将进一步加深。 (3)万维网数据形式的丰富和网络技术的不断发展,图片、数据库、音频、视频多媒体等不同数据大量出现,通用搜索引擎往往对这些信息含量密集且具有一定结构的数据无能为力,不能很好地发现和获取。 (4)通用搜索引擎大多提供基于关键字的检索,难以支持根据语义信息提出的查询。 网络爬虫 为了解决上述问题,定向抓取相关网页资源的聚焦爬虫应运而生。聚焦爬虫是一个自动下载网页的程序,它根据既定的抓取目标,有选择的访问万维网上的网页与相关的链接,获取所需要的信息。与通用爬虫(general purpose web crawler)不同,聚焦爬虫并不追求大的覆盖,而将目标定为抓取与某一特定主题内容相关的网页,为面向主题的用户查询准备数据资源。 传统爬虫从一个或若干初始网页的URL开始,获得初始网页上的URL,在抓取网页的过程中,不断从当前页面上抽取新的URL放入队列,直到满足系统的一定停止条件。聚焦爬虫的工作流程较为复杂,需要根据一定的网页分析算法过滤与主题无关的链接,保留有用的链接并将其放入等待抓取的URL队列。然后,它将根据一定的搜索策略从队列中选择下一步要抓取的网页URL,并重复上述过程,直到达到系统的某一条件时停止。另外,所有被爬虫抓取的网页将会被系统存贮,进行一定的分析、过滤,并建立索引,以便之后的查询和检索;对于聚焦爬虫来说,这一过程所得到的分析结果还可能对以后的抓取过程给出反馈和指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值