我需要选择我在链接之后看到的第一个图像(沿着DOM向上)。我有这样一个代码,但是由于某些原因它不能工作,哪里会有错误呢?
for doc in response.css('a::attr("href")'):
if '/mans/' in doc.get():
image = doc.xpath(f'//a[href={doc.get()}]/preceding::img[1]')
print(image)会不会有语法错误?这是一个分析过的页面的例子...
<tbody>
<tr>
<td>
<img src="Resources/Images/Product images, logos/Alta, Alta HR/Alta_Black_Calendar_Horizontal_Shadow.png" alt="Fitbit Alta with the time shown on the screen" />
</td>
<td>
<p><a href="https://help.fitbit.com/manuals/manual_alta_de.pdf" target="_blank">Deutsch</a>
</p>
<p><a href="https://help.fitbit.com/manuals/manual_alta_en_US.pdf" target="_blank">English</a>
</p>
<p><a href="https://help.fitbit.com/manuals/manual_alta_es.pdf" target="_blank">Español</a>
</p>
</td>
<td>
<p><a href="https://help.fitbit.com/manuals/manual_alta_fr.pdf" target="_blank">Français</a>
</p>
<p><a href="https://help.fitbit.com/manuals/manual_alta_it.pdf" target="_blank">Italiano</a>
</p>
<p><a href="https://help.fitbit.com/manuals/manual_alta_ja.pdf" target="_blank">日本語</a>
</p>
</td>
<td>
<p><a href="https://help.fitbit.com/manuals/manual_alta_ko.pdf" target="_blank">한국어</a>
</p>
<p><a href="https://help.fitbit.com/manuals/manual_alta_zh_CN.pdf" target="_blank">简体中文</a>
</p>
<p><a href="https://help.fitbit.com/manuals/manual_alta_zh_TW.pdf" target="_blank">繁體中文</a>
</p>
</td>
</tr>
</tbody>发布于 2021-11-15 22:35:28
在xpath语句中的href前面放一个@,假设链接之前的元素是一个图像,那么它应该可以工作。
f'//a[@href={doc.get()}]/preceding::img[1]'https://stackoverflow.com/questions/69981141
复制相似问题