Python CSV 文件解析和生成方法示例
作者:常伟佳 发布时间:2022-12-25 10:52:58
思路
简单的生成和读取 CSV
CSV 文件格式
使用 csv 库
Python with CSV
先有个很朴素的生成和解析的方法。
生成:
data = [
[1, 2, 3],
[4, 5, 6],
[7, 8, 9],
]
for cow in data:
print(','.join(map(str, cow)))
生成结果:
1,2,3
4,5,6
7,8,9
解析
s = """1,2,3
4,5,6
7,8,9
"""
cows = s.splitlines()
data = []
for cow in cows:
items = cow.split(',')
data.append(items)
# data
# [['1', '2', '3'], ['4', '5', '6'], ['7', '8', '9']]
但是显示的数据可能不这么理想,比如其中的某一项有 ,
的时候就会有问题了。
CSV 格式
CSV 中有几个概念需要先了解下。CSV 虽然是 Comma-separated values 但并不一定用逗号来分隔,也可以用其他的来分隔。同时 CSV 也没有一个明确的规范。
从 Python 的 csv 的文档中看到的一些关键术语:
delimiter
,最基本的分隔符
quotechar
,如果某个 item 中包含了分隔符,应该用 quotechar 把它包裹起来
doublequote
,如果某个 item 中出现了 quotechar 那么可以把整个内容用 quotechar 包裹,并把 quotechar double 一下用来做区分
escapechar
,如果不用 doublequote 的方法还可以用 escapechar 来辅助
lineterminator
,每一行的结束符,默认的是 \r\n
quoting
,可以选择任何时候都使用 quotechar 来包裹内容,或者是需要用到的时候再用,或者不用
skipinitialspace
,是否忽略分隔符后面跟着的空格
strict
,这个是 Python 自己的,是否抛要异常
(上面的可能没有覆盖所有的细节,但大概就是这样的情况)
使用 Python 的 csv 库
13.1. csv — CSV File Reading and Writing — Python 2.7.12 documentation
很简单的例子就是
import csv
with open('some.csv', 'rb') as f:
reader = csv.reader(f)
for row in reader:
print row
import csv
with open('some.csv', 'wb') as f:
writer = csv.writer(f)
writer.writerows(someiterable)
另外这里面有个 dialect 的概念,就是用一个 dialect 来定义上面提到的那些解析规则。
可以自己注册(csv.register_dialect
)、列出所有的(csv.list_dialects
)、获取某个(csv.get_dialect
)。
默认是用逗号分隔的 excel
的 dialect,所以如果没有特殊情况应该直接使用默认值就够了。
其他
这次先只把基本概念了解下,后面可能还有文件编码之类的坑,到时遇到了再回来更新。
参考
PEP 305 -- CSV File API | Python.org
13.1. csv — CSV File Reading and Writing — Python 2.7.12 documentation
来源:https://segmentfault.com/a/1190000006029896?utm_source=sf-similar-article


猜你喜欢
- 本文实例讲述了python任务调度实现方法。分享给大家供大家参考。具体如下:方法1:import sched, timeimport oss
- 我之前想写路由器的密码暴力破解器,我手上只有极路由,发现极路由有安全限制,只能允许连续10密码错误,所以我改拿博客园练手。博客园的博客有个功
- 一、私有化上篇说过封装,既将我们不想让别人看到代码的内容,但是又需要用到的内容,通过类内部调用来实现调用。说到这里却不得不提一下上篇的:cl
- 0.配置依赖环境,如果不进行这步可能会出现一些问题中间可能有多余空格,去除下再运行,一般都能安装成功,如果不能可以先更新下sudo apt-
- 问题你想将一个模块分割成多个文件。但是你不想将分离的文件统一成一个逻辑模块时使已有的代码遭到破坏。解决方案程序模块可以通过变成包来分割成多个
- 一、Array数组的更改array数组中修改的API示例如下://创建大量相同元素的数组//创建有10个String类型元素的数组,并且每个
- 背景App落地页迭代频繁,且需兼容App与各小App,目前是单向前进迭代,会存在以下问题:跳转原生交互;如:某个落地页增加了只有主App的才
- 如下所示:#! /usr/bin/python3# coding = utf-8# from PyQt5 import QtGui,QtCo
- 这篇文章主要介绍了python 图像处理画一个正弦函数代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 虽然我们一直使用书籍搜索的示例表单,并将起改进的很完美,但是这还是相当的简陋: 只包含一个字段,q。这简单的例子,我们不需要使用Django
- 例子class A(object): def foo(self,x): print "exe
- 1:事件机制共享队列:利用消息机制在两个队列中,通过传递消息,实现可以控制的生产者消费者问题要求:readthread读时,writethr
- 在前面的章节我们已经了解了面向对象的入门知识,知道了如何定义类,如何创建对象以及如何给对象发消息。为了能够更好的使用面向对象编程思想进行程序
- 本文实例讲述了Python列表元素常见操作。分享给大家供大家参考,具体如下:列表类似于java中的数组,用方括号表示,逗号分隔其中的元素#赋
- 多级联动下拉选择框,动态获取下一级,每一级数据为XML,可支持无限级(浏览器端需要Microsoft.XMLDOM支持)项目需要,一个材料类
- 前言异步编程可以提高应用程序的性能和吞吐量,因为它可以充分利用 CPU 和 I/O 资源。当某个任务被阻塞时,事件循环可以切换到另一个任务,
- Javascript有许多内建的方法来产生对话框,如:window.alert(), window.confirm(),window.pro
- 最近写了个python抓取必应搜索首页http://cn.bing.com/的背景图片并将此图片更换为我的电脑桌面的程序,在正则匹配图片ur
- 一,js中对象继承js中有三种继承方式1.js原型(prototype)实现继承<SPAN style="BACKGROUN
- 问题问题1:如何解决事务提交时flush redo log带来的性能损失WAL是实现事务持久性(D)的一个常用技术,基本原理是将事务的修改记