Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/loops/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 在Beauty soup 4中处理.find()失败_Python_Web Scraping_Beautifulsoup - Fatal编程技术网

Python 在Beauty soup 4中处理.find()失败

Python 在Beauty soup 4中处理.find()失败,python,web-scraping,beautifulsoup,Python,Web Scraping,Beautifulsoup,因此,我有很多字段需要多个.find()调用,例如: km1 = soup.find(id='milage').findChild(class_='c2').text.strip km2 = soup.find(id='milage2').findChild(class_='c2').text.strip speed = soup.find(id='speed').findChild(class_='c3').text.strip 现在,用try/catch来包围它们中的每一个都有点愚蠢,并且

因此,我有很多字段需要多个.find()调用,例如:

km1 = soup.find(id='milage').findChild(class_='c2').text.strip
km2 = soup.find(id='milage2').findChild(class_='c2').text.strip
speed = soup.find(id='speed').findChild(class_='c3').text.strip
现在,用try/catch来包围它们中的每一个都有点愚蠢,并且使整个事情变得不可读,我怎么能让它在任何时候失败时都返回某种空值呢?

,你可以使用css选择器,它更容易阅读/编写

km1 = soup.select('#milage .c2')
kml = kml[0].text.strip() if kml else None
,您可以使用css选择器,它更易于阅读/编写

km1 = soup.select('#milage .c2')
kml = kml[0].text.strip() if kml else None
,您可以使用css选择器,它更易于阅读/编写

km1 = soup.select('#milage .c2')
kml = kml[0].text.strip() if kml else None
,您可以使用css选择器,它更易于阅读/编写

km1 = soup.select('#milage .c2')
kml = kml[0].text.strip() if kml else None

select返回一个没有文本的列表,不是吗?为此,您需要执行km1=soup.select('#milage.c2')[0].text.strip(),这将导致IndexOutfrange。@Bernard,您是对的。我更新了答案以使用条件表达式来避免异常。谢谢,我使用了:“.join”([item.text.strip(),用于汤中的项目。select(“#milage.c2”)])将其压缩为一行,但本质上是sameselect返回一个没有文本的列表,不是吗?为此,您需要执行km1=soup.select('#milage.c2')[0].text.strip(),这将导致IndexOutfrange。@Bernard,您是对的。我更新了答案以使用条件表达式来避免异常。谢谢,我使用了:“.join”([item.text.strip(),用于汤中的项目。select(“#milage.c2”)])将其压缩为一行,但本质上是sameselect返回一个没有文本的列表,不是吗?为此,您需要执行km1=soup.select('#milage.c2')[0].text.strip(),这将导致IndexOutfrange。@Bernard,您是对的。我更新了答案以使用条件表达式来避免异常。谢谢,我使用了:“.join”([item.text.strip(),用于汤中的项目。select(“#milage.c2”)])将其压缩为一行,但本质上是sameselect返回一个没有文本的列表,不是吗?为此,您需要执行km1=soup.select('#milage.c2')[0].text.strip(),这将导致IndexOutfrange。@Bernard,您是对的。我更新了答案以使用条件表达式来避免异常。谢谢,我使用了:“.join([item.text.strip(),表示汤中的项目。选择(“#milage.c2”)])将其压缩为一行,但从本质上说,如果你需要,使用
try/catch
并不愚蠢。如果你需要,使用
try/catch
并不愚蠢。如果你需要,使用
try/catch
并不愚蠢。如果你需要,使用
try/catch
也不愚蠢。