lxml解析html

lxml解析text类型的html

读取文本解析节点

from lxml import etree

text=‘‘‘
<div>
    <ul>
         <li class="item-0"><a href="link1.html">第一个</a></li>
         <li class="item-1"><a href="link2.html">second item</a></li>
         <li class="item-0"><a href="link5.html">a属性</a>
     </ul>
 </div>
‘‘‘
html=etree.HTML(text) #初始化生成一个XPath解析对象
result=etree.tostring(html,encoding=‘utf-8‘)   #解析对象输出代码
print(type(html))
print(type(result))
print(result.decode(‘utf-8‘))

读取HTML文件进行解析

from lxml import etree

html=etree.parse(‘test.html‘,etree.HTMLParser()) #指定解析器HTMLParser会根据文件修复HTML文件中缺失的如声明信息
result=etree.tostring(html)   #解析成字节
#result=etree.tostringlist(html) #解析成列表
print(type(html))
print(type(result))
print(result)

获取所有节点

from lxml import etree

html=etree.parse(‘test‘,etree.HTMLParser())
result=html.xpath(‘//*‘)  #//代表获取子孙节点,*代表获取所有

print(type(html))
print(type(result))
print(result)

参考:

python3解析库lxml - Py.qi - 博客园]

lxml解析html

上一篇:RxHttp - 轻量级、可扩展、易使用、完美兼容MVVM、MVC架构的网络封装类库


下一篇:Jsp与Servlet