Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/84.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和beautiful soup的格式错误的html_Python_Html_Web Scraping_Beautifulsoup - Fatal编程技术网

包含python和beautiful soup的格式错误的html

包含python和beautiful soup的格式错误的html,python,html,web-scraping,beautifulsoup,Python,Html,Web Scraping,Beautifulsoup,我正在使用Python3.5、BS4.6、selenium 3.6和phantomjs来清理这个站点。脚本在我位于美国的服务器上运行,我想抓取一个德国站点。但我遇到了一个问题。我下载的html如下所示: <div class="col-md-40 product-highlights-container"><div class="product-filters"><select class="colorfilter__select"><option va

我正在使用Python3.5、BS4.6、selenium 3.6和phantomjs来清理这个站点。脚本在我位于美国的服务器上运行,我想抓取一个德国站点。但我遇到了一个问题。我下载的html如下所示:

<div class="col-md-40 product-highlights-container"><div class="product-filters"><select class="colorfilter__select"><option value="{&quot;ebootisId&quot;:&quot;HW102581-1&quot;,&quot;color&quot;:&quot;Midnight Black&quot;,&quot;colorCode&quot;:&quot;000000&quot;,&quot;colorGroup&quot;:&quot;Schwarz&quot;,&quot;colorGroupCode&quot;:&quot;000000&quot;,&quot;deliveryTime&quot;:&quot;2-3 Werktage&quot;,&quot;default&quot;:true,&quot;images&quot;:[{&quot;small&quot;:&quot;/img/dist/HW102581-1_ZU102869_S_1.png&quot;,&quot;medium&quot;:&quot;/img/dist/HW102581-1_ZU102869_M_1.png&quot;,&quot;large&quot;:&quot;/img/dist/HW102581-1_ZU102869_L_1.png&quot;}],&quot;storage&quot;:&quot;64&quot;,&quot;tariffs&quot;:{&quot;TF102910&quot;:{&quot;ebootisId&quot;:&quot;TF102910&quot;,&quot;price&quot;:49,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet&quot;},&quot;TF101415&quot;:{&quot;ebootisId&quot;:&quot;TF101415&quot;,&quot;price&quot;:49,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=telekom&amp;tarif=comfort-allnet&quot;}},&quot;stock&quot;:1086,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet&quot;,&quot;price&quot;:49,&quot;offer_id&quot;:&quot;5a8bf20d56b4537a4076868a&quot;,&quot;soldout&quot;:false}">Midnight Black</option><option value="{&quot;ebootisId&quot;:&quot;HW102581-2&quot;,&quot;color&quot;:&quot;Arctic Silver&quot;,&quot;colorCode&quot;:&quot;c7ccd0&quot;,&quot;colorGroup&quot;:&quot;Silber&quot;,&quot;colorGroupCode&quot;:&quot;c0c0c0&quot;,&quot;deliveryTime&quot;:&quot;2-3 Werktage&quot;,&quot;default&quot;:false,&quot;images&quot;:[{&quot;small&quot;:&quot;/img/dist/HW102581-2_ZU102869_S_1.png&quot;,&quot;medium&quot;:&quot;/img/dist/HW102581-2_ZU102869_M_1.png&quot;,&quot;large&quot;:&quot;/img/dist/HW102581-2_ZU102869_L_1.png&quot;}],&quot;storage&quot;:&quot;64&quot;,&quot;tariffs&quot;:{&quot;TF102910&quot;:{&quot;ebootisId&quot;:&quot;TF102910&quot;,&quot;price&quot;:49,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=arctic-silver&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet&quot;},&quot;TF101415&quot;:{&quot;ebootisId&quot;:&quot;TF101415&quot;,&quot;price&quot;:49,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=arctic-silver&amp;speicher=64&amp;carrier=telekom&amp;tarif=comfort-allnet&quot;}},&quot;stock&quot;:503,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=arctic-silver&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet&quot;,&quot;price&quot;:49,&quot;offer_id&quot;:&quot;5a8bf20d56b4537a4076868a&quot;,&quot;soldout&quot;:false}">Arctic Silver</option><option value="{&quot;ebootisId&quot;:&quot;HW102581-3&quot;,&quot;color&quot;:&quot;Orchid Grey&quot;,&quot;colorCode&quot;:&quot;9d9dad&quot;,&quot;colorGroup&quot;:&quot;Grau&quot;,&quot;colorGroupCode&quot;:&quot;dcdcdc&quot;,&quot;deliveryTime&quot;:&quot;2-3 Werktage&quot;,&quot;default&quot;:false,&quot;images&quot;:[{&quot;small&quot;:&quot;/img/dist/HW102581-3_ZU102869_S_1.png&quot;,&quot;medium&quot;:&quot;/img/dist/HW102581-3_ZU102869_M_1.png&quot;,&quot;large&quot;:&quot;/img/dist/HW102581-3_ZU102869_L_1.png&quot;}],&quot;storage&quot;:&quot;64&quot;,&quot;tariffs&quot;:{&quot;TF102910&quot;:{&quot;ebootisId&quot;:&quot;TF102910&quot;,&quot;price&quot;:49,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=orchid-grey&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet&quot;},&quot;TF101415&quot;:{&quot;ebootisId&quot;:&quot;TF101415&quot;,&quot;price&quot;:49,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=orchid-grey&amp;speicher=64&amp;carrier=telekom&amp;tarif=comfort-allnet&quot;}},&quot;stock&quot;:500,&quot;url&quot;:&quot;/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=orchid-grey&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet&quot;,&quot;price&quot;:49,&quot;offer_id&quot

您的代码可以更改如下。它将创建一个名为
pretty.html
的输出文件,其中包含
prettify
版本的html:

from bs4 import BeautifulSoup
from selenium import webdriver

link = 'https://tarife.mediamarkt.de/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&speicher=64&carrier=vodafone&tarif=comfort-allnet'
filename = 'output.html'

driver = webdriver.PhantomJS() #executable_path=path_to_pjs)
driver.get(link)

with open(filename, "wb") as f_output:
    f_output.write(driver.page_source.encode('utf-8'))

page_soup = BeautifulSoup(driver.page_source, "lxml")

with open('pretty.html', 'w') as f_output:
    f_output.write(page_soup.prettify())

driver.close()
给你一个
开始:

<div class="col-md-40 product-highlights-container">
 <div class="product-filters">
  <select class="colorfilter__select">
   <option value='{"ebootisId":"HW102581-1","color":"Midnight Black","colorCode":"000000","colorGroup":"Schwarz","colorGroupCode":"000000","deliveryTime":"2-3 Werktage","default":true,"images":[{"small":"/img/dist/HW102581-1_ZU102869_S_1.png","medium":"/img/dist/HW102581-1_ZU102869_M_1.png","large":"/img/dist/HW102581-1_ZU102869_L_1.png"}],"storage":"64","tariffs":{"TF102910":{"ebootisId":"TF102910","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet"},"TF101415":{"ebootisId":"TF101415","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=telekom&amp;tarif=comfort-allnet"}},"stock":1075,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet","price":49,"offer_id":"5a8bf20d56b4537a4076868a","soldout":false}'>


什么是
链接
?然后我们就可以重现这个问题了。谢谢你,真是妙不可言。我遇到了一个小ascii问题,但可以通过使用open(str(I)+“u pretty.html”,“wb”)作为f_输出来解决它:
f_输出。write(page_soup.prettify(encoding='utf-8'))
<div class="col-md-40 product-highlights-container">
 <div class="product-filters">
  <select class="colorfilter__select">
   <option value='{"ebootisId":"HW102581-1","color":"Midnight Black","colorCode":"000000","colorGroup":"Schwarz","colorGroupCode":"000000","deliveryTime":"2-3 Werktage","default":true,"images":[{"small":"/img/dist/HW102581-1_ZU102869_S_1.png","medium":"/img/dist/HW102581-1_ZU102869_M_1.png","large":"/img/dist/HW102581-1_ZU102869_L_1.png"}],"storage":"64","tariffs":{"TF102910":{"ebootisId":"TF102910","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet"},"TF101415":{"ebootisId":"TF101415","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=telekom&amp;tarif=comfort-allnet"}},"stock":1075,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&amp;speicher=64&amp;carrier=vodafone&amp;tarif=comfort-allnet","price":49,"offer_id":"5a8bf20d56b4537a4076868a","soldout":false}'>