我如何通过 xpath select 前一个元素?
How do I select the previous element by xpath?
我需要 select 我在 link 之后看到的第一张图片(向上 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>
在您的 xpath 语句中的 href 前面放置一个 @,它应该可以工作,因为 link 之前的元素是一个图像。
f'//a[@href={doc.get()}]/preceding::img[1]'
我需要 select 我在 link 之后看到的第一张图片(向上 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>
在您的 xpath 语句中的 href 前面放置一个 @,它应该可以工作,因为 link 之前的元素是一个图像。
f'//a[@href={doc.get()}]/preceding::img[1]'