python - lxml.etree為什么會自動加上加上</i>?
問題描述
正在學習lxml,代碼如下:
from lxml import etreetext = ’’’<i class='cell maincell'> <p class='title'><a target='_blank' > <span>洋鼴鼠</span></a> </p> <p><span class='tags t-small c-gray-aset'> <a >電子商務</a></span><span class='loca c-gray-aset t-small'> <a >天津</a></span> </p></i>’’’html = etree.HTML(text)print(etree.tostring(html,encoding=’utf-8’).decode(’utf-8’))
輸出如下:
<html><body><i class='cell maincell'> </i><p class='title'><a target='_blank' > <span>洋鼴鼠</span></a> </p> <p><span class='tags t-small c-gray-aset'> <a >電子商務</a></span><span class='loca c-gray-aset t-small'> <a >天津</a></span> </p></body></html>
主要不理解為什么<i>標簽那里會出錯呢?請問怎么解決這個問題?謝謝~
問題解答
回答1:主要是因為
p元素內容分類 Flow content, palpable content.允許的內容 Phrasing content.允許的父元素任何接受flow content的元素
i元素Content catergories Flow content, phrasing content, palpable content.允許量 phrasing content.
很顯然P元素的父元素應該是flow content類型的,然而i并不滿足條件,也就是說這是不符合規范的。解決辦法就是i直接換為p。
相關文章:
1. golang - 用IDE看docker源碼時的小問題2. html - css氣泡,實現“倒三角(不知道算不算三角了)”可透明的。3. phpstudy8.1沒集成mysql-front4. java - 如何點擊按鈕,重新運行(我是初學者)?5. 運行python程序時出現“應用程序發生異常”的內存錯誤?6. 我何時應該在Java中使用JFrame.add(component)和JFrame.getContentPane()。add(component)7. 利用IPMI遠程安裝centos報錯!8. 前端 - @media query 使用出現的問題?9. html5和Flash對抗是什么情況?10. javascript - 請指條明路,angular的$event,在select中卻是undefined?

網公網安備