如何删除逗号之间的空格和多余逗号,并用python在csv中将它们替换为“”

2024-04-19 00:38:43 发布

您现在位置:Python中文网/ 问答频道 /正文

这是我的CSV:

AAP,AAMC,AAPL,AMT

106.08999633789062,,,

,122.88999938964844,,

,,109.80000305175781,

,,,118.55000305175781

在这里,我的第二行是在楼梯中打印的,因为所有的','和换行符。如何使用python获得同一行中的所有数据缩进?你知道吗

我试过使用。替换函数,但它需要硬编码时间到了。是吗有一种方法我可以找到这样的模式:

因此,预期输出如下:

AAP,AAMC,AAPL,AMT
106.08999633789062,122.88999938964844,109.80000305175781,118.55000305175781

Tags: csv数据方法函数编码时间模式aapl
3条回答

试试这个:

import csv
data = {}
with open('input.txt') as input_file:
    reader = csv.DictReader(input_file, delimiter=',')
    for row in reader:
        for key, value in row.items():
            if value:
                data[key] = value
with open('output.txt', 'w', newline='') as output_file:
    writer = csv.DictWriter(output_file, delimiter=',', fieldnames=data.keys())
    writer.writeheader()
    writer.writerow(data)

数据为:

{'AAMC': '122.88999938964844',
 'AAP': '106.08999633789062',
 'AAPL': '109.80000305175781',
 'AMT': '118.55000305175781'}

你知道吗输出.txt地址:

AAP,AAMC,AAPL,AMT
106.08999633789062,122.88999938964844,109.80000305175781,118.55000305175781

您可以尝试使用以下代码:

import pandas as pd 
df=pd.read_csv("a.csv",delimeter=',',skipinitialspace=True,delim_whitespace=True)
print(list(df.keys()))
print(list(df.values()))
df.to_csv("b.csv",index=False)

有一种方法:

import pandas as pd

df = pd.read_csv('a.csv')
m = df.max()
print(list(m.keys())); print(list(m.values))
# => ['AAP', 'AAMC', 'AAPL', 'AMT']
# => [106.08999633789062, 122.88999938964844, 109.8000030517578, 118.5500030517578]

相关问题 更多 >