python中修改csv的一行数据(python修改csv字段的值)

http://www.itjxue.com  2023-04-10 05:07  来源:未知  点击次数: 

python如何修改csv文件的内容

你可以读取 这个csv 文件, 读取里面的数据。

然后再把 这些数据处理之后, 写入到 另一个 csv 文件。

(然后你还可以, 将原来的删除)

python怎么同时定义csv的行列

Python对csv文件进行行列的增加操作方法,这里通过实例向大家讲解,代码如下:

方法一:

import csv

d = list(range(38685))

with open('./hh.csv') as f1:

f_csv = csv.DictReader(f1)

for i, row in enumerate(f_csv):

#print(row)

key1 = hello'

value1 = 'test'

row[key1] = value1

key2 = 'hahaha'

value2 = '0'

row[key2] = value2

d[i] = row

f1.close()

方法二:

headers = ['hello', 'youtube_id', 'time_start', 'time_end', 'split', 'hahaha']

with open('./hh.csv', 'w') as f:

f_csv = csv.DictWriter(f, headers)

f_csv.writeheader()

f_csv.writerows(d)

f.close()

with open('./hh.csv','rt') as fin:

lines=''

for line in fin:

if line!='\n':

lines+=line

with open('./hh.csv','wt')as fout:

fout.write(lines)

在上面的所有中,我们分别使用了两种不同的方式来对csv文件进行行列的增加,第一种方法,首先先用一个excel表打开一个csv文件,对它进行手动添加了hello和hahaha。第二种方法,是直接利用python里面的csv模块进行改写操作,在对csv文件进行操作的时候,会增添许多的空行,在倒数第7行的代码开始,就是对csv文件中多出来的空格进行处理。

说说如何利用 Python 处理 CSV 文件

CSV 表示 “Comma-Separated Values (逗号分隔的值) ” , CSV 文件是简化的电子表格,实际为纯文本文件。

一个 CSV 文件,格式是这样的:

因为 CSV 文件中的每个单元格都是以逗号分割,所以也许有人会对每行文本调用 split() 方法,来解析 CSV 文件。但 CSV 文件也有自己的转义字符,通过转义字符,允许逗号和其他字符作为值的一部分,但单纯使用 split() 方法不能处理这些转义字符。因为这些潜在的缺陷,所以建议总是使用 csv 模块来读写 CSV 文件。

csv 模块是 Python 自带的,所以可以直接导入。

要使用 csv 模块从 CSV 文件中读取数据,我们需要创建一个 Reader 对象。 通过 Reader 对象,我们可以迭代遍历 CSV 文件中的每一行内容。

运行结果:

要用 csv 模块读取 CSV 文件,首先先使用 open() 函数打开它 ,就像打开任何其他文本文件一样。然后将它传递给 csv .reader() 函数。 这个函数将返回一个 Reader 对象。注意,csv .reader() 函数不接受文件名作为入参。

要访问 Reader 对象中的值,最直接的方法,就是利用 list() 将它转换成一个普通 Python 列表。它实际为一个包含列表的列表,用于表示二维数据。

我们还可以使用表达式 data [ row ][ col ] 来访问 CSV 中特定行和列的值。其中, row 是 data 中一个列表的下标, col 是该列表中,我们想访问的项的下标:

运行结果:

运行结果:

Writer 对象可以让我们把数据写入 CSV 文件。

运行结果:

在 Windows 上,需要为 open() 函数的 newline 关键字参数传入一个空字符串。如果没有设置 newline 参数, output.csv 中的行距将变为两倍,如下图所示。

如果写入的内容包含逗号,那么 csv 模块会自动加上双引号,对其进行转义,如下例所示。

运行结果:

我们也可以利用 delimiter ,来制作 TSV 文件,TSV 是Tab-separated values的缩写,即以制表符作为分隔符的文件;利用 lineterminator 参数来设定行距。

运行结果:

这里利用 lineterminator='\n\n\n' 将行与行之间的字符变为三个换行符,效果就是实现了 3 倍行距。

python如何修改csv某列数值?

f=open('xxx','r',encoding='utf-8')

file=f.readlines()

f.close()

f=open('xxx','w',encoding='utf-8')

for i in len(file):

----file[i]=file[i].split(',')

----file[i][1]=99

----for j in file[i]:

--------f.write(j+',')

----f.write('\n')

f.close()

python处理csv某行数据

import?pandas?as?pd

my_csv?=?pd.read_csv('myfile',skiprows?=?[10,20,15])

python修改csv文件

不能写入原文件。。。

要么写到另外文件,要么在文件的基础上追加,要么覆盖源文件。。不可能在一行读入后修改完再写到这一行。。

(责任编辑:IT教学网)

更多

推荐照片处理文章