开发者社区> 问答> 正文

python程序合并文件怎么做:报错 

我只是做一个很小的程序合并文件,我有三个文件,每个文件有两列,一列ID, 一列分子密码,我希望合并三个文档以id重复的删去重复行。本人初学python,不太会。
比如文件一: Z0121  banana Z0122  apple

第二个文件: Z0122   raisin Z023  peach

我最后想得到: Z0121 banana Z0122  apple Z0123  peach

展开
收起
kun坤 2020-06-04 21:15:58 403 0
1 条回答
写回答
取消 提交回答
  • cat 1.txt 2.txt |awk '{if(!($1 in a)){print;}a[$1]=1;}'

    ######

    from StringIO import StringIO import csv

    #模拟文件对象 s1 = StringIO( ''' Z0121 banana Z0122 apple ''') s2 = StringIO(''' Z0122 raisin Z0123 peach ''')

    m1 = {} m2 = {}

    #csv方式读文件 csv1 = csv.DictReader(s1, fieldnames=['id','name'], delimiter=' ', skipinitialspace=True, dialect='excel') for row in csv1: print row m1[row['id']] = row['name']

    csv2 = csv.DictReader(s2, fieldnames=['id','name'], delimiter=' ', skipinitialspace=True, dialect='excel') for row in csv2: print row m2[row['id']] = row['name']

    #m2合并到m1 for k, v in m2.items(): if k not in m1: m1[k] = v print m1

    ######

    引用来自“周翼翼”的评论

    cat 1.txt 2.txt |awk '{if(!($1 in a)){print;}a[$1]=1;}'

    不好意思,我要的不是这个,我需要的是它忽略水果名不同只要id,如果水果名不同取第一文件中对应的水果名,而且你写的不是python指令######还有别的答案吗?

    2020-06-08 09:47:39
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
From Python Scikit-Learn to Sc 立即下载
Data Pre-Processing in Python: 立即下载
双剑合璧-Python和大数据计算平台的结合 立即下载