Python Beautiful Soup - 获取输入值

Python Beautiful Soup - Getting input value

我的计划是能够使用Bs4获取_AntiCsrfToken。

我有这个 HTML 我的 HTML 来自

而我在代码中写的是

token = soup.find('input', {'name':'_AntiCsrfToken'})['value'])
print(token)

但它给了我一个错误

    Traceback (most recent call last):
  File "C:\Users\HelloWorld.py", line 67, in <module>
    print(soup.find('input', {'name':'_AntiCsrfToken'})['value'])
  File "C:\Python\lib\site-packages\bs4\element.py", line 1292, in find
    l = self.find_all(name, attrs, recursive, text, 1, **kwargs)
AttributeError: 'str' object has no attribute 'find_all'

我很不明白我做的对不对。我确实认为我做对了,但也许我需要先从 form-id 中找到它,而不是直接进入隐藏状态?

我不确定你的错误在哪里,但我已经制作了一个小 html 文件并将其放在我的服务器上,我可以毫无问题地复制和粘贴你的代码..

唯一明显的区别(如果你还没有这样做的话)是我使用请求将 html 解析为 BS4

我想可能是解析问题。

HTML

<html>

<form action="process">
<input type="hidden" name="_AntiCsrfToken" value="5435434354353453545">

</form>
</html>

Python:

from bs4 import BeautifulSoup as bs4
import requests

r = requests.get('http://maffaz.com/so.html')
html_bytes = r.text
soup = bs4(html_bytes, 'lxml')
token = soup.find('input', {'name':'_AntiCsrfToken'})['value']
print(token)

returns:

5435434354353453545

你也不需要

{'name':'_AntiCsrfToken'}

所以:

token = soup.find('input')['value']

会工作

也许尝试使用 CSS selectors

from bs4 import BeautifulSoup

html = """
<html>
<input type="hidden" name="_AntiCsrfToken" value="5435434354353453545">
</html>
"""

soup = BeautifulSoup(html, 'lxml')
csrf = soup.select_one('input[name=_AntiCsrfToken]')['value']
print(csrf)

输出:5435434354353453545