色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

利用python 讀寫csv文件

瀏覽:5日期:2022-07-11 16:17:21

1、讀文件

import csv csv_reader = csv.reader(open('data.file', encoding='utf-8'))for row in csv_reader: print(row)

csv_reader把每一行數據轉化成了一個list,list中每個元素是一個字符串。

2、寫文件

讀文件時,我們把csv文件讀入列表中,寫文件時會把列表中的元素寫入到csv文件中。

list = ['1', '2', '3', '4']out = open(outfile, 'w')csv_writer = csv.writer(out)csv_writer.writerow(list)

可能遇到的問題:直接使用這種寫法會導致文件每一行后面會多一個空行。

解決辦法如下:

out = open(outfile, 'w', newline='')csv_writer = csv.writer(out, dialect='excel')csv_writer.writerow(list)

在stackoverflow上找到了比較經典的解釋,原來 python3里面對 str和bytes類型做了嚴格的區分,不像python2里面某些函數里可以混用。所以用python3來寫wirterow時,打開文件不要用wb模式,只需要使用w模式,然后帶上newline=’’。

3、示例

簡單讀寫

import csv class writer: def __init__(self): self.dict = { '標題': '標題', '鏈接': '鏈接', '服務': '服務', 'dsr': 'dsr', '店鋪名': '店鋪名', '價格': '店鋪名', '付款人數': '付款人數', '發貨地': '發貨地', } 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', '標題': '我是標題', } a.dict.update(new) print(a.dict) a.writer_to(a.dict.values()) 結合爬蟲

import csvfrom selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.ui import WebDriverWaitfrom selenium.webdriver.support import expected_conditions as ECfrom selenium.common.exceptions import TimeoutException, NoSuchElementExceptionfrom selenium.webdriver.common.action_chains import ActionChains driver = ['1', '2']colspan = ['1', '2']try: out = open('類目.csv', 'w', newline='')except PermissionError: print('文件被其他程序占用') input('')csv_writer = csv.writer(out, dialect='excel')csv_writer.writerow(['寶貝ID', '類目']) def open_chrome(): driver[0] = webdriver.Chrome() driver[0].get('https://www.dianchacha.com') input('請登陸后按回車:') def EC_located(one_group, value): ''' 目的:簡化代碼長度,參數1選擇one或者group切換選中模式 :param value:要找的值【CSS選擇器】 :return:選擇到的對象 ''' 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元素未加載成功,等待超時') else: try: ecl = wait.until(EC.presence_of_all_elements_located((By.CSS_SELECTOR, value)) ) return ecl except TimeoutException: print(value, '1元素---組---未加載成功,等待超時') 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('寶貝類目: ', '') 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 讀寫csv文件的詳細內容,更多關于python 讀寫csv文件的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 爱福利极品盛宴 | 美女黄色在线看 | 久久国产精品-久久精品 | 国产三级理论 | 亚洲天堂区 | 99久热在线精品视频播放6 | 武松大战潘金莲三级在线 | 亚洲天堂久久精品成人 | 久久免费国产精品一区二区 | 亚洲第一中文字幕 | 九九草在线观看 | 欧美第一页草草影院浮力 | 亚洲国产精品综合久久20 | 中国精品视频一区二区三区 | 亚洲在线免费观看视频 | 免费精品国产 | 久久久国产99久久国产一 | 亚洲欧美日韩综合在线一区二区三区 | 国产在线视频一区 | 嫩草一区二区三区四区乱码 | 老人毛片| 91大神大战丝袜美女在线观看 | 9lporm自拍视频在线 | 国产精品久久久久久福利漫画 | 女在床上被男的插爽叫视频 | 久草免费在线 | 国产一级一片 | 最新欧美精品一区二区三区不卡 | 国产成人免费观看在线视频 | 毛片免费看看 | 免费看成人www的网站软件 | 小明台湾成人永久免费看看 | 中文字幕成人免费高清在线 | 亚洲人成在线播放网站 | 97视频久久 | 成人的天堂 | 亚洲精品国产精品国自产网站 | 美女视频黄a视频美女大全 美女视频黄a视频免费全程 | 97在线观看免费视频 | 好吊色37pao在线观看 | 亚洲天堂久久新 |