您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

使用dictwriter覆盖相同csv文件中的行

5b51 2022/1/14 8:22:06 python 字数 1940 阅读 560 来源 www.jb51.cc/python

我有names.csvfirst_name,last_name Baked,Beans Lovely,Spam John,Bang Harry,Potter 我想在同一个文件中用“jason statham”重命名“John Ban”.我试图使用file.seek()但失败了import csv with open('/home/tiwari/Desktop

概述

我有names.csv

first_name,last_name
Baked,Beans
Lovely,Spam
John,Bang
Harry,Potter

我想在同一个文件中用“jason statham”重命名“John Ban”.
我试图使用file.seek()但失败了

import csv
with open('/home/tiwari/Desktop/names.csv','rw+') as csvfile:
    fieldnames = ['first_name','last_name']
    writer = csv.DictWriter(csvfile,fieldnames=fieldnames)
    reader = csv.DictReader(csvfile)
    for line,row in enumerate(reader):
        rs = sys.getsizeof(row)
        if row['first_name'] == 'John':
            csvfile.seek(-rs)
            writer.writerow({'first_name': 'Jason','last_name': 'statham'})

我建议读取所有行,并替换它们,并将其写回.

import csv

with open('/home/tiwari/Desktop/names.csv','r+') as csvfile:
    reader = csv.DictReader(csvfile)

    rows = []
    for row in reader:
        if row['first_name'] == 'John':
            row['first_name'] = 'Jason'
            row['last_name'] = 'Statham'
        rows.append(row)

    csvfile.seek(0)  # back to begining of the file.
    fieldnames = ['first_name',fieldnames=fieldnames)
    writer.writeheader()
    writer.writerows(rows)
    csvfile.truncate()  # In case of updated content is shorter.

总结

以上是编程之家为你收集整理的使用dictwriter覆盖相同csv文件中的行全部内容,希望文章能够帮你解决使用dictwriter覆盖相同csv文件中的行所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶