我正在学习如何使用 lxml 解析文档。为此,我尝试解析我的 linkedin 页面。它有很多信息,我认为这将是一次很好的培训。上下文足够了。这是我正在做的:转到网址: https: //www.linkedin.com/in/NAME/打开源代码并将其保存为“linkedin.html”当我试图摆脱当前的工作时,我正在执行以下操作:from io import StringIO, BytesIOfrom lxml import html, etree# read filefilename = 'linkedin.html'file = open(filename).read()# building parserparser = etree.HTMLParser()tree = etree.parse(StringIO(file), parser)# parse an elementtitle = tree.xpath('/html/body/div[6]/div[4]/div[3]/div/div/div/div/div[2]/main/div[1]/section/div[2]/div[2]/div[1]/h2')print(title)树变量的类型是但它总是为我的变量标题返回一个空列表。我已经尝试了一整天,但仍然不明白我做错了什么。
1 回答
梵蒂冈之花
TA贡献1900条经验 获得超5个赞
我通过在 open() 函数中添加编码参数找到了问题的答案。
这是我所做的:
def parse_html_file(filename):
f = open(filename, encoding="utf8").read()
parser = etree.HTMLParser()
tree = etree.parse(StringIO(f), parser)
return tree
tree = parse_html_file('linkedin.html')
name = tree.xpath('//li[@class="inline t-24 t-black t-normal break-words"]')
print(name[0].text.strip())
- 1 回答
- 0 关注
- 95 浏览
添加回答
举报
0/150
提交
取消