
本文介绍如何使用 Pandas 分析客户交付数据,提取并统计特定客户链的出现频率。通过对数据进行排序、去重和分组聚合,最终得到不同客户链及其出现的次数或比例,帮助你发现潜在的交付模式。
在实际业务场景中,我们经常需要分析客户的购买行为、访问路径或交付顺序等数据,从中发现隐藏的模式和规律。本文将以客户交付数据为例,演示如何使用 Pandas 提取并统计客户链,帮助你更好地理解客户行为。
数据准备
首先,我们需要准备包含交付数据的 Pandas DataFrame。DataFrame 至少包含以下几列:
以下是一个示例 DataFrame:
import pandas as pd
data = {'DateTime': ['01/01/2023 09:00:00', '01/01/2023 09:10:00', '01/01/2023 09:15:00',
'01/01/2023 12:00:00', '01/01/2023 12:00:10', '01/01/2023 12:15:00',
'01/01/2023 15:00:00', '01/01/2023 15:05:10', '01/01/2023 15:15:00',
'01/01/2023 15:30:10', '01/01/2023 15:35:15'],
'SortieNumber': [1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3],
'CustomerName': ['Josh', 'Alice', 'Robert', 'Anna', 'Anna', 'Robert', 'Josh', 'Alice', 'Robert', 'Robert', 'Robert'],
'ProductCode': ['001', '002', '002', '001', '003', '003', '004', '003', '001', '002', '003']}
df = pd.DataFrame(data)
print(df)数据处理
接下来,我们需要对 DataFrame 进行处理,提取客户链并统计其出现频率。
排序: 首先,按照 SortieNumber 和 DateTime 对 DataFrame 进行排序,确保同一批次内的客户按照交付时间先后顺序排列。
df = df.sort_values(by=['SortieNumber', 'DateTime']) print(df)
去重: 移除同一 SortieNumber 下连续重复的 CustomerName。 如果在一次批次中,同一客户连续出现多次,我们只保留第一次出现。
df = df.loc[lambda d: d[['SortieNumber', 'CustomerName']].ne(d[['SortieNumber', 'CustomerName']].shift()).any(axis=1)] # 或者,如果确定同一个 SortieNumber 中,同一个客户不会被其他客户分割,可以使用更简洁的方法: # df = df.drop_duplicates(['SortieNumber', 'CustomerName']) print(df)
分组聚合: 按照 SortieNumber 对 DataFrame 进行分组,并将每个批次内的客户名称用 "-" 连接起来,形成客户链。
customer_chains = df.groupby('SortieNumber')['CustomerName'].agg('-'.join)
print(customer_chains)统计频率: 使用 value_counts() 函数统计每个客户链出现的次数。
chain_counts = customer_chains.value_counts() print(chain_counts)
结果展示
最终,我们可以得到每个客户链及其出现的次数。例如,Josh-Alice-Robert 出现了 2 次,Anna-Robert 出现了 1 次。
如果需要展示客户链出现的比例,可以将 normalize=True 传递给 value_counts() 函数。
chain_proportions = customer_chains.value_counts(normalize=True) print(chain_proportions)
完整代码
以下是完整的代码示例:
import pandas as pd
data = {'DateTime': ['01/01/2023 09:00:00', '01/01/2023 09:10:00', '01/01/2023 09:15:00',
'01/01/2023 12:00:00', '01/01/2023 12:00:10', '01/01/2023 12:15:00',
'01/01/2023 15:00:00', '01/01/2023 15:05:10', '01/01/2023 15:15:00',
'01/01/2023 15:30:10', '01/01/2023 15:35:15'],
'SortieNumber': [1, 1, 1, 2, 2, 2, 3, 3, 3, 3, 3],
'CustomerName': ['Josh', 'Alice', 'Robert', 'Anna', 'Anna', 'Robert', 'Josh', 'Alice', 'Robert', 'Robert', 'Robert'],
'ProductCode': ['001', '002', '002', '001', '003', '003', '004', '003', '001', '002', '003']}
df = pd.DataFrame(data)
chain_counts = (df.sort_values(by=['SortieNumber', 'DateTime'])
.loc[lambda d: d[['SortieNumber', 'CustomerName']]
.ne(d[['SortieNumber', 'CustomerName']].shift())
.any(axis=1)]
.groupby('SortieNumber')['CustomerName'].agg('-'.join)
.value_counts()
)
print(chain_counts)
chain_proportions = (df.sort_values(by=['SortieNumber', 'DateTime'])
.loc[lambda d: d[['SortieNumber', 'CustomerName']]
.ne(d[['SortieNumber', 'CustomerName']].shift())
.any(axis=1)]
.groupby('SortieNumber')['CustomerName'].agg('-'.join)
.value_counts(normalize=True)
)
print(chain_proportions)总结
通过本文的教程,你学会了如何使用 Pandas 分析客户交付数据,提取客户链并统计其出现频率。这种方法可以应用于各种场景,例如分析用户在网站上的访问路径、分析客户的购买行为等,帮助你发现隐藏的模式和规律,从而更好地理解客户行为,优化业务流程。
注意事项
以上就是使用 Pandas 分析客户链:提取客户交付顺序模式的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号