利用python 讀寫(xiě)csv文件
1、讀文件
import csv
csv_reader = csv.reader(open("data.file", encoding="utf-8"))
for row in csv_reader:
print(row)
csv_reader把每一行數(shù)據(jù)轉(zhuǎn)化成了一個(gè)list,list中每個(gè)元素是一個(gè)字符串。
2、寫(xiě)文件
讀文件時(shí),我們把csv文件讀入列表中,寫(xiě)文件時(shí)會(huì)把列表中的元素寫(xiě)入到csv文件中。
list = ["1", "2", "3", "4"] out = open(outfile, "w") csv_writer = csv.writer(out) csv_writer.writerow(list)
可能遇到的問(wèn)題:直接使用這種寫(xiě)法會(huì)導(dǎo)致文件每一行后面會(huì)多一個(gè)空行。
解決辦法如下:
out = open(outfile, "w", newline="") csv_writer = csv.writer(out, dialect="excel") csv_writer.writerow(list)
在stackoverflow上找到了比較經(jīng)典的解釋?zhuān)瓉?lái) python3里面對(duì) str和bytes類(lèi)型做了嚴(yán)格的區(qū)分,不像python2里面某些函數(shù)里可以混用。所以用python3來(lái)寫(xiě)wirterow時(shí),打開(kāi)文件不要用wb模式,只需要使用w模式,然后帶上newline=''。
3、示例
- 簡(jiǎn)單讀寫(xiě)
import csv
class writer:
def __init__(self):
self.dict = {
"標(biāo)題": "標(biāo)題",
"鏈接": "鏈接",
"服務(wù)": "服務(wù)",
"dsr": "dsr",
"店鋪名": "店鋪名",
"價(jià)格": "店鋪名",
"付款人數(shù)": "付款人數(shù)",
"發(fā)貨地": "發(fā)貨地",
}
out = open("outfile.csv", "w", newline="")
self.csv_writer = csv.writer(out, dialect="excel")
self.csv_writer.writerow(self.dict)
def writer_to(self, key_value):
self.csv_writer.writerow(key_value)
if __name__ == "__main__":
a = writer()
new = {
"鏈接": "http://www.baidu.com",
"標(biāo)題": "我是標(biāo)題",
}
a.dict.update(new)
print(a.dict)
a.writer_to(a.dict.values())
- 結(jié)合爬蟲(chóng)
import csv
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.common.exceptions import TimeoutException, NoSuchElementException
from selenium.webdriver.common.action_chains import ActionChains
driver = ["1", "2"]
colspan = ["1", "2"]
try:
out = open("類(lèi)目.csv", "w", newline="")
except PermissionError:
print("文件被其他程序占用")
input("")
csv_writer = csv.writer(out, dialect="excel")
csv_writer.writerow(["寶貝ID", "類(lèi)目"])
def open_chrome():
driver[0] = webdriver.Chrome()
driver[0].get("https://www.dianchacha.com")
input("請(qǐng)登陸后按回車(chē):")
def EC_located(one_group, value):
"""
目的:簡(jiǎn)化代碼長(zhǎng)度,參數(shù)1選擇one或者group切換選中模式
:param value:要找的值【CSS選擇器】
:return:選擇到的對(duì)象
"""
wait = WebDriverWait(driver[0], 10)
if one_group == "one":
try:
ecl = wait.until(EC.presence_of_element_located((By.CSS_SELECTOR, value)))
return ecl
except TimeoutException:
print(value, "1元素未加載成功,等待超時(shí)")
else:
try:
ecl = wait.until(
EC.presence_of_all_elements_located((By.CSS_SELECTOR, value))
)
return ecl
except TimeoutException:
print(value, "1元素---組---未加載成功,等待超時(shí)")
def operating(ID):
# 先獲取ID輸入框
driver[0].get("https://www.dianchacha.com/item/info/index/iid/" + ID)
html = driver[0].page_source
if "未能找到親的寶貝" not in html:
colspans = EC_located("group", ".colspan-1")
colspan[0] = str(colspans[1].text).replace("寶貝類(lèi)目: ", "")
else:
return operating(ID)
print(colspan)
def writer_txt():
csv_writer.writerow([url[0], colspan[0]])
print("保存", url[0], colspan[0], "成功")
url = ["0", "1"]
def main():
open_chrome()
file = "寶貝ID.txt"
with open(file) as f:
for line in f.readlines():
url[0] = line
print(line)
operating(url[0])
writer_txt()
out.close()
print("已完成")
if __name__ == "__main__":
main()
以上就是利用python 讀寫(xiě)csv文件的詳細(xì)內(nèi)容,更多關(guān)于python 讀寫(xiě)csv文件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python使用Altair創(chuàng)建交互式數(shù)據(jù)可視化的操作指南
Altair 是一個(gè)基于 Vega-Lite 的 Python 數(shù)據(jù)可視化庫(kù),它旨在簡(jiǎn)化數(shù)據(jù)可視化的創(chuàng)建過(guò)程,尤其適用于統(tǒng)計(jì)圖表的生成,Altair 強(qiáng)調(diào)聲明式編碼方式,通過(guò)簡(jiǎn)單的語(yǔ)法,用戶(hù)能夠快速創(chuàng)建復(fù)雜的交互式圖表,本文將介紹 Altair 的基礎(chǔ)用法、常見(jiàn)圖表類(lèi)型,需要的朋友可以參考下2024-12-12
python作圖基礎(chǔ)之plt.contour實(shí)例詳解
contour和contourf都是畫(huà)三維等高線圖的,下面這篇文章主要給大家介紹了關(guān)于python作圖基礎(chǔ)操作之plt.contour的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
python 寫(xiě)的一個(gè)爬蟲(chóng)程序源碼
這篇文章主要介紹了python 寫(xiě)的一個(gè)爬蟲(chóng)程序源碼,需要的朋友可以參考下2016-02-02
關(guān)于Python正則表達(dá)式 findall函數(shù)問(wèn)題詳解
在寫(xiě)正則表達(dá)式的時(shí)候總會(huì)遇到不少的問(wèn)題,本文講述了Python正則表達(dá)式中 findall()函數(shù)和多個(gè)表達(dá)式元組相遇的時(shí)候會(huì)出現(xiàn)的問(wèn)題2018-03-03
Python中l(wèi)ogging日志模塊代碼調(diào)試過(guò)程詳解
這篇文章主要介紹了Python中l(wèi)ogging日志模塊代碼調(diào)試,今天來(lái)看看如何在代碼中定義日志,并探討日志的權(quán)限,需要的朋友可以參考下2023-04-04
使用python將excel數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)過(guò)程詳解
這篇文章主要介紹了使用python將excel數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08
Python?自動(dòng)控制原理?control的詳細(xì)解說(shuō)
這篇文章主要介紹了Python自動(dòng)控制原理control的詳細(xì)解說(shuō),文章圍繞主題展開(kāi)對(duì)Python?control的介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下2022-07-07

