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 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("类目.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文件的资料请关注其它相关文章!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】