利用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编程中三条常用的技巧
May 11 Python
Python2.x中文乱码问题解决方法
Jun 02 Python
Python函数式编程指南(三):迭代器详解
Jun 24 Python
使用Python的Bottle框架写一个简单的服务接口的示例
Aug 25 Python
Linux中安装Python的交互式解释器IPython的教程
Jun 13 Python
python 中的divmod数字处理函数浅析
Oct 17 Python
解决python3读取Python2存储的pickle文件问题
Oct 25 Python
Python Matplotlib 基于networkx画关系网络图
Jul 10 Python
Python操作Sonqube API获取检测结果并打印过程解析
Nov 27 Python
Python Tornado批量上传图片并显示功能
Mar 26 Python
Django中F函数的使用示例代码详解
Jul 06 Python
python 绘制国旗的示例
Sep 27 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
解析二进制流接口应用实例 pack、unpack、ord 函数使用方法
2013/06/18 PHP
解析PHP中数组元素升序、降序以及重新排序的函数
2013/06/20 PHP
再推荐十款免费的php开发工具
2015/11/09 PHP
php 如何获取文件的后缀名
2016/06/05 PHP
静态页面下用javascript操作ACCESS数据库(读增改删)的代码
2007/05/14 Javascript
如何确保JavaScript的执行顺序 之实战篇
2011/03/03 Javascript
『jQuery』.html(),.text()和.val()的概述及使用
2013/04/22 Javascript
从数据结构的角度分析 for each in 比 for in 快的多
2013/07/07 Javascript
JS判断数组中是否有重复值得三种实用方法
2013/08/16 Javascript
下拉列表选择项的选中在不同浏览器中的兼容性问题探讨
2013/09/18 Javascript
ArtEditor富文本编辑器增加表单提交功能
2016/04/18 Javascript
基于jQuery和hwSlider实现内容左右滑动切换效果附源码下载(一)
2016/06/22 Javascript
JS取模、取商及取整运算方法示例
2016/10/13 Javascript
babel的使用及安装配置教程
2018/02/22 Javascript
vue填坑之webpack run build 静态资源找不到的解决方法
2018/09/03 Javascript
iView-admin 动态路由问题的解决方法
2018/10/03 Javascript
js实现倒计时秒杀效果
2020/03/25 Javascript
uni-app 组件里面获取元素宽高的实现
2019/12/27 Javascript
[15:20]DOTA2亚洲邀请赛总决赛开幕式表演:羽泉献唱
2017/04/05 DOTA
Python模块学习 datetime介绍
2012/08/27 Python
python进阶教程之循环相关函数range、enumerate、zip
2014/08/30 Python
在Django的session中使用User对象的方法
2015/07/23 Python
python实现下载整个ftp目录的方法
2017/01/17 Python
解决Python3中的中文字符编码的问题
2018/07/18 Python
python write无法写入文件的解决方法
2019/01/23 Python
使用Python画股票的K线图的方法步骤
2019/06/28 Python
python如何给字典的键对应的值为字典项的字典赋值
2019/07/05 Python
python 字符串常用函数详解
2019/09/11 Python
浅析CSS3 中的 transition,transform,translate之间区别和作用
2020/03/26 HTML / CSS
YSL Beauty加拿大官方商城:圣罗兰美妆加拿大
2017/05/15 全球购物
自荐信的禁忌和要点
2013/10/15 职场文书
毕业生文员求职信
2013/11/03 职场文书
护理专科毕业推荐信
2013/11/10 职场文书
大学生最新职业生涯规划书范文
2014/01/12 职场文书
2015年六年级班主任工作总结
2015/10/15 职场文书
JS函数式编程实现XDM一
2022/06/16 Javascript