Ich versuche, die generierte Liste in eine CSV-Datei zu exportieren, wobei jede Zeile in der Webseitentabelle einer neuen Zeile in der Datei entspricht und jeder Wert in einer einzelnen Zelle steht :Schreiben von Python-Listenwerten in eine CSV-Datei
NAME.....ICO DATE....ICO PRICE....CURR. PRICE....24 HR ROI Stratis.....06/20/16.......$0.007...........$7.480................+38.80%
die aktuelle Ausgabe wie folgt aussieht:
['Patientory\n05/31/17\n$0.104\n$0.274\n+46.11%\n+25.54%\nN/A']
import csv
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait as wait
csvrows = []
def get_css_sel(selector):
posts = browser.find_elements_by_css_selector(selector)
for post in posts:
print(post.text)
csvrows.append([post.text])
browser = webdriver.Chrome(executable_path=r'C:\Scrapers\chromedriver.exe')
browser.get("https://icostats.com")
wait(browser, 20).until(EC.presence_of_element_located((By.CSS_SELECTOR, "#app > div > div.container-0-16 > div.table-0-20 > div.tbody-0-21 > div:nth-child(2) > div:nth-child(8)")))
get_css_sel("#app > div > div.container-0-16 > div.table-0-20 > div.tableheader-0-50") #fetch header of table
get_css_sel("#app > div > div.container-0-16 > div.table-0-20 > div.tbody-0-21 > div") #fetch rows of table
def create_csv(thelist):
with open('ICO.csv', 'w') as myfile:
for i in thelist:
wr = csv.writer(myfile, quoting=csv.QUOTE_ALL)
wr.writerow([i])
create_csv(csvrows)
Das ist es! Wie kann ich die Anführungszeichen entfernen? Ich kann remove() nicht aufrufen: AttributeError: 'NoneType' -Objekt hat kein Attribut 'remove' – tklein
Welche Anführungsstriche möchten Sie entfernen? In der CSV-Datei haben Sie "quoting = csv.QUOTE_ALL" angegeben. Entfernen Sie das, wenn Sie keine unnötigen Anführungszeichen benötigen. Außerdem ist der [Standard "Dialekt" "Excel"] (https://docs.python.org/3/library/csv.html#csv.writer), was normalerweise ausreichend ist. – aneroid
Wenn Sie leere Zeilen und keinen Text für 'post.text' erhalten, dann setzen Sie' if post.text: 'vor' csvrows.append ... '. – aneroid