鱼C论坛

 找回密码
 立即注册
查看: 1802|回复: 6

[已解决]求python代码,统计保单号出现的第几次

[复制链接]
发表于 2023-5-22 13:51:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x

【求助帖】请及时确认最佳答案,下次提问时可以得到更多关注,问题可以更快解决
保单号+                  个数            新单号
A13219013676                            A13219013676
A13219013776                            A13219013776   
A13289259876                            A13289259876
A13289259857                            A13289259857
A13289259857         1                 A13289259857-1
A13289259877                            A13289259877
A13289259877         1                 A13289259877 -1
A13289259877         2                 A13289259877 -2

个数列如果只有单号唯一一个不显示,重复第一个不显示,重复的第二个显示1,重复的第三个的显示2,,最后添加新列,命名为新单号,保存到excel后个数列,这么显示
最佳答案
2023-5-22 14:22:05
冰菲 发表于 2023-5-22 14:15
last_data['单号'] = np.where(last_data['个数']==0,last_data['保单号+'],last_data['保单号+']+"-"+st ...


你想要的新列"新单号",需要对每一行进行操作,所以我们需要使用 apply() 函数来对每一行进行操作。以下是修改后的代码:
import pandas as pd

# 读取Excel文件
df = pd.read_excel('input.xlsx')

# 创建一个字典来跟踪每个保单号的出现次数
count_dict = {}

# 创建一个新列来保存出现的次数
df['个数'] = 0

for i in range(len(df)):
    policy_number = df.loc[i, '保单号+']
    if policy_number in count_dict:
        count_dict[policy_number] += 1
        df.loc[i, '个数'] = count_dict[policy_number]
    else:
        count_dict[policy_number] = 0

# 添加新单号列
df['新单号'] = df.apply(lambda row: row['保单号+'] if row['个数']==0 else row['保单号+'] + "-" + str(row['个数']), axis=1)

# 保存到新的Excel文件中
df.to_excel('output.xlsx', index=False)
这段代码将对每一行应用一个函数,该函数会检查"个数"列是否为0。如果为0,它将只使用"保单号+"的值,否则,它将在"保单号+"的值后添加一个连字符和"个数"的值。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-5-22 14:10:07 | 显示全部楼层
你怎么老是问同一个问题?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-5-22 14:15:05 | 显示全部楼层
isdkz 发表于 2023-5-22 14:10
你怎么老是问同一个问题?

last_data['单号'] = np.where(last_data['个数']==0,last_data['保单号+'],last_data['保单号+']+"-"+str(last_data['个数']))

把的填完,我继续完善功能,新加单号,保存到excel中就显示一堆,不是想要的,提示<class 'pandas.core.series.Series'>
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-22 14:22:05 | 显示全部楼层    本楼为最佳答案   
冰菲 发表于 2023-5-22 14:15
last_data['单号'] = np.where(last_data['个数']==0,last_data['保单号+'],last_data['保单号+']+"-"+st ...


你想要的新列"新单号",需要对每一行进行操作,所以我们需要使用 apply() 函数来对每一行进行操作。以下是修改后的代码:
import pandas as pd

# 读取Excel文件
df = pd.read_excel('input.xlsx')

# 创建一个字典来跟踪每个保单号的出现次数
count_dict = {}

# 创建一个新列来保存出现的次数
df['个数'] = 0

for i in range(len(df)):
    policy_number = df.loc[i, '保单号+']
    if policy_number in count_dict:
        count_dict[policy_number] += 1
        df.loc[i, '个数'] = count_dict[policy_number]
    else:
        count_dict[policy_number] = 0

# 添加新单号列
df['新单号'] = df.apply(lambda row: row['保单号+'] if row['个数']==0 else row['保单号+'] + "-" + str(row['个数']), axis=1)

# 保存到新的Excel文件中
df.to_excel('output.xlsx', index=False)
这段代码将对每一行应用一个函数,该函数会检查"个数"列是否为0。如果为0,它将只使用"保单号+"的值,否则,它将在"保单号+"的值后添加一个连字符和"个数"的值。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2023-5-22 14:26:14 | 显示全部楼层
isdkz 发表于 2023-5-22 14:22
你想要的新列"新单号",需要对每一行进行操作,所以我们需要使用 apply() 函数来对每一行进行操作。以 ...

太棒了,感谢!!!,理解能力真强,我还怕我没介绍清楚呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-22 14:27:25 | 显示全部楼层
冰菲 发表于 2023-5-22 14:26
太棒了,感谢!!!,理解能力真强,我还怕我没介绍清楚呢

不客气,是chatgpt的理解能力强
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-5-22 14:37:55 | 显示全部楼层
isdkz 发表于 2023-5-22 14:27
不客气,是chatgpt的理解能力强

我只会写简单的代码,你的代码逻辑我都不懂,能跑就行了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-23 03:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表