我如何通过 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]'