您的位置 首页 编程知识

如何从包含多列数据的 CSV 文件中合并特定列并计算各个选项出现的比例?

csv 文件合并与内容比例计算 问题: 如何从包含多列数据的 csv 文件中读取内容并合并特定的列,同时计算各…

如何从包含多列数据的 CSV 文件中合并特定列并计算各个选项出现的比例?

csv 文件合并与内容比例计算

问题:

如何从包含多列数据的 csv 文件中读取内容并合并特定的列,同时计算各个选项出现的比例?

解决方案:

使用 的 pandas 库来处理 csv 文件:

import pandas as pd from collections import Counter  # 读取 CSV 文件 df = pd.read_csv('test.csv', encoding='cp932')  # 获取 CMD 列作为主键 index_list_cmd = df['cmd'].tolist()  # 计算 CMD 出现的次数 idxLstCmd_cnt = Counter(list(index_list_cmd))  # 去除重复的 CMD index_list_cmd = sorted(set(index_list_cmd), key=list(index_list_cmd).index)  # 计算每个 CMD 出现的次数 cntLst = [] for lst_i in range(len(index_list_cmd)):     cntLst.append(idxLstCmd_cnt[index_list_cmd[lst_i]])  # 合并 OPT 列 index_list_opt_idx = []  # 删除之前保存的文件 if os.path.isfile(useRateF):     os.remove(useRateF)  # 遍历 CMD for cmd_i in range(len(index_list_cmd)):     # 获得 OPT 列的 index     index_list_opt_idx = list(df['opt'][df['cmd'] == index_list_cmd[cmd_i]].index.values)      index_list_opt = []      # 遍历 OPT     for opt_i in range(len(index_list_opt_idx)):         try:             index_list_opt.append(df.loc[int(index_list_opt_idx[opt_i]), 'opt'])         except:             print(index_list_cmd[cmd_i])             print(index_list_opt_idx[opt_i])             print(opt_i)      # 列表转字符串     str_idxLstOpt = ' '.join(index_list_opt)      # 字符串转回列表     lst_idxLstOpt = str_idxLstOpt.split(' ')      # 计算 OPT 出现的比例     for tag in sorted(set(lst_idxLstOpt), key=lst_idxLstOpt.index):         with open(useRateF, 'a', encoding='utf-8_sig') as uf:             uf.writelines(str(index_list_cmd[cmd_i]) + ',' + tag + ',' + str(lst_idxLstOpt.count(tag)/cntLst[cmd_i]))             uf.writelines('n')
登录后复制

这个脚本将读取 csv 文件,合并 opt 列,并输出每个 cmd 选项出现的比例。

以上就是如何从包含多列数据的 CSV 文件中合并特定列并计算各个选项出现的比例?的详细内容,更多请关注php中文网其它相关文章!

本文来自网络,不代表四平甲倪网络网站制作专家立场,转载请注明出处:http://www.elephantgpt.cn/3113.html

作者: nijia

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

联系我们

18844404989

在线咨询: QQ交谈

邮箱: 641522856@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部