0

0

使用 Pandas 分析客户链:提取客户交付顺序模式

碧海醫心

碧海醫心

发布时间:2025-07-31 21:24:01

|

498人浏览过

|

来源于php中文网

原创

使用 pandas 分析客户链:提取客户交付顺序模式

本文介绍如何使用 Pandas 分析客户交付数据,提取并统计特定客户链的出现频率。通过对数据进行排序、去重和分组聚合,最终得到不同客户链及其出现的次数或比例,帮助你发现潜在的交付模式。

在实际业务场景中,我们经常需要分析客户的购买行为、访问路径或交付顺序等数据,从中发现隐藏的模式和规律。本文将以客户交付数据为例,演示如何使用 Pandas 提取并统计客户链,帮助你更好地理解客户行为。

数据准备

首先,我们需要准备包含交付数据的 Pandas DataFrame。DataFrame 至少包含以下几列:

  • DateTime: 交付时间
  • SortieNumber: 批次号
  • CustomerName: 客户名称
  • ProductCode: 产品代码

以下是一个示例 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 进行处理,提取客户链并统计其出现频率。

  1. 排序: 首先,按照 SortieNumber 和 DateTime 对 DataFrame 进行排序,确保同一批次内的客户按照交付时间先后顺序排列

    df = df.sort_values(by=['SortieNumber', 'DateTime'])
    print(df)
  2. 去重: 移除同一 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)
  3. 分组聚合: 按照 SortieNumber 对 DataFrame 进行分组,并将每个批次内的客户名称用 "-" 连接起来,形成客户链。

    方舟订单管理系统
    方舟订单管理系统

    系统开发由二当家的编写,代码完全开源,可自行修改源码,欢迎使用! 1、网站采用php语言开发,更安全、稳定、无漏洞、防注入、防丢单。 2、记录订单来路,客户IP记录及分析,订单数据统计 3、订单邮件提醒、手机短信提醒,让您第一时间追踪订单,大大提升了发货效率,提高订单成交率。 4、多种支付方式,包含:货到付款、支付宝接口、网银支付,可设置在线支付的折扣比率。 5、模板样式多样化,一个订单放到多个网

    下载
    customer_chains = df.groupby('SortieNumber')['CustomerName'].agg('-'.join)
    print(customer_chains)
  4. 统计频率: 使用 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 分析客户交付数据,提取客户链并统计其出现频率。这种方法可以应用于各种场景,例如分析用户在网站上的访问路径、分析客户的购买行为等,帮助你发现隐藏的模式和规律,从而更好地理解客户行为,优化业务流程。

注意事项

  • 在实际应用中,你需要根据数据的具体情况调整代码。例如,如果数据中包含缺失值,你需要先处理缺失值。
  • 如果数据量非常大,可以考虑使用更高效的数据处理工具,例如 Spark。
  • 客户链的长度可以根据实际需求进行调整。例如,你可以只提取长度为 2 或 3 的客户链。
  • 需要注意数据隐私,避免泄露客户的敏感信息。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

49

2025.12.04

常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

954

2023.11.02

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

4

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.1万人学习

Pandas 教程
Pandas 教程

共15课时 | 0.9万人学习

ASP 教程
ASP 教程

共34课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号