python读取文件csv,按数值列排序

python读取文件csv,按数值列排序

最近用python弄三张表格的合并,期间对文件列进行排序,发现一个不错的代码:

from operator import itemgetter

input_file = open("PDBhaemoglobinReport.csv")
output_file = open("PDBhaemoglobinSorted.csv","w")

table = []
header = input_file.readline() #读取并弹出第一行
for line in input_file:
    col = line.split(',') #每行分隔为列表,好处理列格式
    col[3] = float(col[3][1:-1])
    col[4] = int(col[4][1:-2]) #各行没有先strip 末位是\n
    table.append(col) #嵌套列表table[[8,8][*,*],...]

table_sorted = sorted(table, key=itemgetter(3, 4))#先后按列索引3,4排序

output_file.write(header + '\t')
for row in table_sorted:                    #遍历读取排序后的嵌套列表
    row = [str(x) for x in row]             #转换为字符串格式,好写入文本
    output_file.write("\t".join(row) + '\n')

input_file.close()
output_file.close()

附数据如下:

=
PDBhaemoglobinReportcsv内容

PDB ID,Chain ID,Exp. Method,Resolution,Chain Length
“1A4F”,“A”,“X-RAY DIFFRACTION”,“2.00”,“141”
“1C7C”,“A”,“X-RAY DIFFRACTION”,“1.80”,“283”
“1CG5”,“A”,“X-RAY DIFFRACTION”,“1.60”,“141”
“1FAW”,“A”,“X-RAY DIFFRACTION”,“3.09”,“141”
“1HDA”,“A”,“X-RAY DIFFRACTION”,“2.20”,“141”
“1IRD”,“A”,“X-RAY DIFFRACTION”,“1.25”,“141”
“1KFR”,“A”,“X-RAY DIFFRACTION”,“1.85”,“147”
“1QPW”,“A”,“X-RAY DIFFRACTION”,“1.80”,“141”
“1SPG”,“A”,“X-RAY DIFFRACTION”,“1.95”,“144”
“1UX8”,“A”,“X-RAY DIFFRACTION”,“2.15”,“132”

PDBhaemoglobinSorted.csv :

PDB ID,Chain ID,Exp. Method,Resolution,Chain Length
“2W72” “A” “X-RAY DIFFRACTION” 1.07 141
“1IRD” “A” “X-RAY DIFFRACTION” 1.25 141
“2H8F” “A” “X-RAY DIFFRACTION” 1.3 143
“2WY4” “A” “X-RAY DIFFRACTION” 1.35 140
“2D5X” “A” “X-RAY DIFFRACTION” 1.45 141
“4ESA” “A” “X-RAY DIFFRACTION” 1.45 143
“3VRG” “A” “X-RAY DIFFRACTION” 1.5 141
“1CG5” “A” “X-RAY DIFFRACTION” 1.6 141
“4HBI” “A” “X-RAY DIFFRACTION” 1.6 146
“1QPW” “A” “X-RAY DIFFRACTION” 1.8 141

######本人AI小白,希望各位多多指教!

原文链接:https://www.cnblogs.com/koujiaodahan/p/8047109.html

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值