下面是一个我想清理的html示例:
<figure class="floatRight" style="margin-left: 30px">
<a class="zoomFunction alignLeft" href="https://www.thieme-connect.de/media/synthesis/EFirst/lookinside/ss-2015-c0259-st_10-1055_s-0034-1378861-1.jpg"><img src="https://www.thieme-connect.de/media/synthesis/EFirst/lookinside/thumbnails/ss-2015-c0259-st_10-1055_s-0034-1378861-1.jpg"/></a>
<figcaption></figcaption>
</figure>
<p>
<a name="N65743"></a>
</p><h3>Abstract</h3>
<p>2-<span class="i">tert</span>-Butyl-5-iodoindolizine underwent Sonogashira reaction with acetylenes in the presence of dichlorobis(triphenylphosphine)palladium, copper(I) iodide, and triethylamine in acetonitrile to give to the corresponding 5-ethynylindolizines in high yields; 5-iodo-2-phenylindolizine and 5-bromo-2-<span class="i">tert</span>-butylindolizine did not undergo the reaction. Several structures were characterized by X-ray. The 5-ethynylindolizines did not undergo cyclization to give cycl[3.2.2]azines.</p>
<div class="articleKeywords">
<a name="N65760"></a>
<h3>Key words</h3>
5-iodoindolizines -
Sonogashira reaction -
5-ethynylindolizine -
X-ray
</div>
<a name="N67312"></a>
<h3>Supporting Information</h3>
<ul class="linkList">Supporting information for this article is available online at http://dx.doi.org/10.1055/s-0034-1378861.<li>
<a class="gotolink" href="https://www.thieme-connect.de/media/synthesis/EFirst/supmat/sup_ss-2015-c0259-st_10-1055_s-0034-1378861.pdf">Supporting Information</a>
</li>
</ul>
我基本上会这样做:
from bs4 import BeautifulSoup
with open("test.xml", 'r') as file:
soup = BeautifulSoup(file.read(), "lxml")
abstract = soup
[tag.extract() for tag in abstract("a", attrs={"name": True})]
[tag.extract() for tag in abstract("h3")]
[tag.extract() for tag in abstract("ul", attrs={"class": "linkList"})]
[tag.extract() for tag in abstract("a", attrs={"class": "gotolink"})]
print(abstract)
我希望多个extract()行清除每个匹配的标记。但是,只有第一个有效!我可以去掉“a”标签,但不能去掉“h3”标签。如果我对第一个提取行(用于“a”标记的那一行)进行注释,我可以去掉“h3”标记,但不能去掉其他标记。你知道吗
有点奇怪。你知道我为什么会有这种行为吗?你知道吗
我使用从pip新安装的BeautifulSoup4.4.0
诀窍是在每次提取后创建一个新的漂亮的Soup对象,并在此新对象上执行下一次提取。你知道吗
这看起来可能有点难看,但它是有效的:
干净.py
输出
清洁前
清洁后
好吧抱歉伙计们,这个虫子其实是来自美女团。当降级到4.3.2-3时,完全相同的代码可以完美地工作。我会报告的。抱歉,我在发帖前没有检查。你知道吗
相关问题 更多 >
编程相关推荐