利用python 读写csv文件


Posted in Python onSeptember 10, 2020

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文件的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python 元类使用说明
Dec 18 Python
Python数据分析之双色球中蓝红球分析统计示例
Feb 03 Python
解决python删除文件的权限错误问题
Apr 24 Python
Python实现确认字符串是否包含指定字符串的实例
May 02 Python
python框架中flask知识点总结
Aug 17 Python
Opencv+Python 色彩通道拆分及合并的示例
Dec 08 Python
python基础梳理(一)(推荐)
Apr 06 Python
python实现抖音点赞功能
Apr 07 Python
python fuzzywuzzy模块模糊字符串匹配详细用法
Aug 29 Python
Python换行与不换行的输出实例
Feb 19 Python
解决pyPdf和pyPdf2在合并pdf时出现异常的问题
Apr 03 Python
Python使用OpenCV实现虚拟缩放效果
Feb 28 Python
如何用Python 加密文件
Sep 10 #Python
Python 高效编程技巧分享
Sep 10 #Python
python操作redis数据库的三种方法
Sep 10 #Python
Python计算矩阵的和积的实例详解
Sep 10 #Python
python如何运行js语句
Sep 09 #Python
python如何爬取动态网站
Sep 09 #Python
python如何停止递归
Sep 09 #Python
You might like
PHP+Mysql+jQuery实现动态展示信息
2011/10/08 PHP
PHP实现服务器状态监控的方法
2014/12/09 PHP
PHP文件读取功能的应用实例
2015/05/08 PHP
php实现粘贴截图并完成上传功能
2015/05/17 PHP
jQuery之网页换肤实现代码
2011/04/30 Javascript
js string 转 int 注意的问题小结
2013/08/15 Javascript
JS获取键盘上任意按键的值(实例代码)
2013/11/12 Javascript
Javascript实现返回上一页面并刷新的小例子
2013/12/11 Javascript
JS+CSS实现美化的下拉列表框效果
2015/08/11 Javascript
JavaScript弹窗基础篇
2016/04/27 Javascript
详解Javascript中prototype属性(推荐)
2016/09/03 Javascript
jQuery图片轮播(二)利用构造函数和原型创建对象以实现继承
2016/12/06 Javascript
JavaScript实现QQ列表展开收缩扩展功能
2017/10/30 Javascript
Gulp实现静态网页模块化的方法详解
2018/01/09 Javascript
JavaScript实现一个带AI的井字棋游戏源码
2018/05/21 Javascript
vue+egg+jwt实现登录验证的示例代码
2019/05/18 Javascript
vue 获取视频时长的实例代码
2019/08/20 Javascript
vue动态子组件的两种实现方式
2019/09/01 Javascript
vue+elementUI动态生成面包屑导航教程
2019/11/04 Javascript
Python类的用法实例浅析
2015/05/27 Python
python正则中最短匹配实现代码
2018/01/16 Python
Python socket实现简单聊天室
2018/04/01 Python
tensorflow更改变量的值实例
2018/07/30 Python
Python设计模式之观察者模式原理与用法详解
2019/01/16 Python
django的csrf实现过程详解
2019/07/26 Python
GAP欧盟网上商店:GAP EU
2016/09/13 全球购物
Perfume’s Club英国官网:购买香水和护肤品
2019/11/02 全球购物
添柏岚英国官方网站:Timberland英国
2019/11/28 全球购物
工商管理本科毕业生求职信范文
2013/10/05 职场文书
出口公司经理求职简历中的自我评价
2013/10/13 职场文书
晚会邀请函范文
2014/01/24 职场文书
励志演讲稿大全
2014/08/21 职场文书
2015关爱留守儿童工作总结
2014/12/12 职场文书
服务员岗位职责
2015/02/03 职场文书
董事长助理岗位职责
2015/02/11 职场文书
导游词之塘栖古镇
2019/12/04 职场文书