python之读取cdv

  csv是Comma-Separated Values的缩写,是用文本文件形式储存的表格数据,比如如下的表格:

就可以存储为csv文件,文件内容是:
No.,Name,Age,Score
1,Apple,12,98
2,Ben,13,97
3,Celia,14,96
4,Dave,15,95

假设上述csv文件保存为"A.csv",如何用Python像操作Excel一样提取其中的一列,即一个字段,利用Python自带的csv模块,有两种方法可以实现:

第一种方法使用reader函数,接收一个可迭代的对象(比如csv文件),能返回一个生成器,就可以从其中解析出csv的内容:比如下面的代码可以读取csv的全部内容,以行为单位:import csv
with open(‘A.csv‘,‘rb‘) as csvfile:
    reader = csv.reader(csvfile)
    rows= [row for row in reader]
print rows
得到:[[‘No.‘, ‘Name‘, ‘Age‘, ‘Score‘],
[‘1‘, ‘Apple‘, ‘12‘, ‘98‘],
[‘2‘, ‘Ben‘, ‘13‘, ‘97‘],
[‘3‘, ‘Celia‘, ‘14‘, ‘96‘],
[‘4‘, ‘Dave‘, ‘15‘, ‘95‘]]

要提取其中某一列,可以用下面的代码:
import csv
with open(‘A.csv‘,‘rb‘) as csvfile:
    reader = csv.reader(csvfile)
    column = [row[2] for row in reader]
print column
得到:[‘Age‘, ‘12‘, ‘13‘, ‘14‘, ‘15‘]
注意从csv读出的都是str类型。这种方法要事先知道列的序号,比如Age在第2列,而不能根据‘Age‘这个标题查询。这时可以采用第二种方法:

第二种方法是使用DictReader,和reader函数类似,接收一个可迭代的对象,能返回一个生成器,但是返回的每一个单元格都放在一个字典的值内,而这个字典的键则是这个单元格的标题(即列头)。用下面的代码可以看到DictReader的结构:
import csv
with open(‘A.csv‘,‘rb‘) as csvfile:
    reader = csv.DictReader(csvfile)
    column = [row for row in reader]
print column
得到:[{‘Age‘: ‘12‘, ‘No.‘: ‘1‘, ‘Score‘: ‘98‘, ‘Name‘: ‘Apple‘},
{‘Age‘: ‘13‘, ‘No.‘: ‘2‘, ‘Score‘: ‘97‘, ‘Name‘: ‘Ben‘},
{‘Age‘: ‘14‘, ‘No.‘: ‘3‘, ‘Score‘: ‘96‘, ‘Name‘: ‘Celia‘},
{‘Age‘: ‘15‘, ‘No.‘: ‘4‘, ‘Score‘: ‘95‘, ‘Name‘: ‘Dave‘}]

如果我们想用DictReader读取csv的某一列,就可以用列的标题查询:
import csv
with open(‘A.csv‘,‘rb‘) as csvfile:
    reader = csv.DictReader(csvfile)
    column = [row[‘Age‘] for row in reader]
print column
就得到:
[‘12‘, ‘13‘, ‘14‘, ‘15‘]          

时间: 2024-10-23 00:22:43

python之读取cdv的相关文章

python 逐行读取文本

f = open("foo.txt") # 返回一个文件对象line = f.readline() # 调用文件的 readline()方法while line: print line, # 后面跟 ',' 将忽略换行符 # print(line, end = '') # 在 Python 3中使用 line = f.readline() f.close() 也可以写成以下更简洁的形式 for line in open("foo.txt"): print line,

python专题-读取xml文件

关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 什么是xml? xml即可扩展标记语言,它可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. abc.xml <?xml version="1.0" encoding="utf-8"?> <catalog> <max

一文贯通python文件读取

p.p1 {margin: 0.0px 0.0px 0.0px 0.0px; -webkit-hyphens: auto; font: 24.0px 'Helvetica Neue'; color: #3e3e3e; -webkit-text-stroke: #3e3e3e} p.p2 {margin: 0.0px 0.0px 0.0px 0.0px; -webkit-hyphens: auto; font: 16.0px 'Helvetica Neue'; color: #8c8c8c; -w

[Python]xlrd 读取excel 日期类型2种方式

有个excle表格需要做一些过滤然后写入数据库中,但是日期类型的cell取出来是个数字,于是查询了下解决的办法. 基本的代码结构 data = xlrd.open_workbook(EXCEL_PATH) table = data.sheet_by_index(0) lines = table.nrows cols = table.ncols print u'The total line is %s, cols is %s'%(lines, cols) 读取某个单元格: table.cell(x

Delphi中使用python脚本读取Excel数据

Delphi中使用python脚本读取Excel数据2007-10-18 17:28:22标签:Delphi Excel python原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://seewind.blog.51cto.com/249547/46669前段时间,在正式项目中使用Python来读取Excel表格的数据.具体需求是,项目数据库中有些数据需要根据Excel表格里面的数据进行一些调整,功能应该比较简单.为了学习Pyth

Python逐行读取文件内容

Python逐行读取文件内容thefile= open("foo.txt") line = thefile.readline() while line: print line, line = thefile.readline() thefile.close() Windows下文件路径的写法:E:/codes/tions.txt 写文件:thefile= open("foo.txt", "rw+")for item in thelist: the

Python 中读取csv文件中有中文的情况

Python 中读取csv文件中有中文的情况,提示编码问题: 读取的时候: import sys reload(sys) #中文错误 sys.setdefaultencoding( "utf-8" ) save 存储的时候: dataframe可以使用to_csv方法方便地导出到csv文件中,如果数据中含有中文,一般encoding指定为"utf-8″,否则导出时程序会因为不能识别相应的字符串而抛出异常,index指定为False表示不用导出dataframe的index数据

python逐行读取文件脚本

逐行读取的方法很多,这里提供一种非常简单的方法: #!/usr/bin/python # -*- coding: utf-8 -*- for line in open("awip.conf"): print line 其他的可以参考教程:python逐行读取文件内容的三种方法Python--文件读取 原文地址:http://blog.51cto.com/weiruoyu/2140927

python逐行读取

From:https://blog.csdn.net/enweitech/article/details/78790888 下面是四种Python逐行读取文件内容的方法, 并分析了各种方法的优缺点及应用场景,以下代码在python3中测试通过, python2中运行部分代码已注释,稍加修改即可. 方法一:readline函数 1 2 3 4 5 6 7 8 #-*- coding: UTF-8 -*-  f = open("/pythontab/code.txt")