Сортировать текстовый файл по совокупному итогу одного столбца из сгруппированных значений в другом столбце, используя только стандартную библиотеку? - PullRequest
0 голосов
/ 06 февраля 2019

У меня есть файл с такими строками

id, car_type, cost
1, benz, 60000
2, benz, 55000
3, bmw, 30000
4, benz, 25000
5, bmw, 26000
6, ford, 5000

Я хочу отсортировать этот файл по общей стоимости каждого car_type.Общая стоимость, например, для 'benz' будет 60000 + 55000 + 25000 = 14000

, поэтому окончательный результат должен составлять

benz, 140000
bmw, 56000
ford, 5000

Пока что это то, что у меня есть:

file = "small_sample.txt"


f=open(file,"r")
lines=f.readlines()[1:]
car_and_cost ={}
for x in lines:
    cost = x.split(',')[4].rstrip('\n')
    car_and_cost.update({x.split(',')[3]:float(cost)})
f.close()
print(car_and_cost)

new_dic = {}
for key,lis in car_and_cost.items():
    new_dic[key] = sum(lis)
print(new_dic)

Я застрял.Во-первых, у словаря, который я генерирую из этого, есть неправильные итоги, и также я просто не знаю, как отсортировать словарь по значению

Ответы [ 2 ]

0 голосов
/ 06 февраля 2019

Использование панд:

import pandas as pd
df = pd.read_csv(logFile)

result = df.groupby(' car_type').sum()
print(result)

ВЫХОД:

           id    cost
 car_type            
 benz       7  140000
 bmw        8   56000
 ford       6    5000

РЕДАКТИРОВАТЬ:

logFile = "tem.csv"
array = []
import csv

with open("tem.csv", "r+") as fin:
    for row in csv.reader(fin):
        array.append(row[1:])

dd = {k: 0 for k in dict(array).keys()}
for x in array: dd[x[0]] += int(x[1])
print(dd)

ВЫХОД:

{' benz': 140000, ' bmw': 56000, ' ford': 5000}

ИЛИ, еслиВы хотите их в списке:

print([[k,v] for k,v in  dd.items()])

ВЫХОД:

[[' benz', 140000], [' bmw', 56000], [' ford', 5000]]
0 голосов
/ 06 февраля 2019

Это один подход с использованием модулей csv и collections

Пример:

import csv
from collections import defaultdict, OrderedDict

result = defaultdict(int)

with open(filename) as infile:
    reader = csv.DictReader(infile)
    for row in reader:                    #Iterate Each row
        result[row[" car_type"]] += int(row[" cost"])   #Add costs

print(OrderedDict(sorted(result.items(), key=lambda x: x[1], reverse=True)))

Выход:

OrderedDict([(' benz', 140000), (' bmw', 56000), (' ford', 5000)])
...