[英]malformed html with python and beautiful soup
我正在使用帶有bs 4.6,selenium 3.6和phantomjs的python 3.5來刮取這個站點。 該腳本在我位於美國的服務器上運行,我想抓取一個德國站點。 但是我遇到了一個問題。 我下載的html看起來像這樣:
<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&speicher=64&carrier=vodafone&tarif=comfort-allnet"},"TF101415":{"ebootisId":"TF101415","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&speicher=64&carrier=telekom&tarif=comfort-allnet"}},"stock":1086,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&speicher=64&carrier=vodafone&tarif=comfort-allnet","price":49,"offer_id":"5a8bf20d56b4537a4076868a","soldout":false}">Midnight Black</option><option value="{"ebootisId":"HW102581-2","color":"Arctic Silver","colorCode":"c7ccd0","colorGroup":"Silber","colorGroupCode":"c0c0c0","deliveryTime":"2-3 Werktage","default":false,"images":[{"small":"/img/dist/HW102581-2_ZU102869_S_1.png","medium":"/img/dist/HW102581-2_ZU102869_M_1.png","large":"/img/dist/HW102581-2_ZU102869_L_1.png"}],"storage":"64","tariffs":{"TF102910":{"ebootisId":"TF102910","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=arctic-silver&speicher=64&carrier=vodafone&tarif=comfort-allnet"},"TF101415":{"ebootisId":"TF101415","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=arctic-silver&speicher=64&carrier=telekom&tarif=comfort-allnet"}},"stock":503,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=arctic-silver&speicher=64&carrier=vodafone&tarif=comfort-allnet","price":49,"offer_id":"5a8bf20d56b4537a4076868a","soldout":false}">Arctic Silver</option><option value="{"ebootisId":"HW102581-3","color":"Orchid Grey","colorCode":"9d9dad","colorGroup":"Grau","colorGroupCode":"dcdcdc","deliveryTime":"2-3 Werktage","default":false,"images":[{"small":"/img/dist/HW102581-3_ZU102869_S_1.png","medium":"/img/dist/HW102581-3_ZU102869_M_1.png","large":"/img/dist/HW102581-3_ZU102869_L_1.png"}],"storage":"64","tariffs":{"TF102910":{"ebootisId":"TF102910","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=orchid-grey&speicher=64&carrier=vodafone&tarif=comfort-allnet"},"TF101415":{"ebootisId":"TF101415","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=orchid-grey&speicher=64&carrier=telekom&tarif=comfort-allnet"}},"stock":500,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=orchid-grey&speicher=64&carrier=vodafone&tarif=comfort-allnet","price":49,"offer_id"
它基本上是一長行文本,這使我無法找到我要查找的標簽。
如果我使用在線美化器或自己拆分產品線,則效果很好,但這不是可行的解決方案。
我試圖使用bs4中的prettify()
函數,但是那也不起作用。
那就是相關的代碼段:
driver = webdriver.PhantomJS(executable_path = path_to_pjs)
driver.get(link)
f = open(filename, "wb")
f.write(driver.page_source.encode('utf-8'))
f.close()
driver.close()
ecj_data = open(filename ,'r', encoding='utf-8').read()
page_soup = soup(ecj_data,"lxml")
page_soup=page_soup.prettify()
您可以更改以下代碼。 它將創建一個名為pretty.html
的輸出文件, pretty.html
包含HTML的prettify
版本:
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>
開始:
<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&speicher=64&carrier=vodafone&tarif=comfort-allnet"},"TF101415":{"ebootisId":"TF101415","price":49,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&speicher=64&carrier=telekom&tarif=comfort-allnet"}},"stock":1075,"url":"/smartphones/samsung/galaxy-s8-inkl-gear-sport?farbe=midnight-black&speicher=64&carrier=vodafone&tarif=comfort-allnet","price":49,"offer_id":"5a8bf20d56b4537a4076868a","soldout":false}'>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.