登录
首页 >  文章 >  python教程

非直连渠道数据提取全攻略

时间:2026-05-08 09:04:07 339浏览 收藏

本文深入解析了如何在Pandas中高效、准确地为每位客户提取首次与末次非“Direct”渠道(即首触点与最后非直接触点),并智能兜底处理全为“Direct”的边缘情况——既满足归因分析中剔除低价值直接访问的核心业务需求,又通过向量化操作、分组聚合与时间排序保障结果的严谨性与百万级数据下的高性能,是用户行为分析与营销归因场景中兼具实用性与工程鲁棒性的标准解决方案。

提取客户首次与末次非直连渠道(跳过“Direct”)的完整实现指南

本文介绍如何在Pandas中为每位客户高效提取其访问记录中首个和末个非“Direct”渠道;若全为“Direct”,则回退取“Direct”本身,并确保按时间顺序准确判断。

本文介绍如何在Pandas中为每位客户高效提取其访问记录中**首个和末个非“Direct”渠道**;若全为“Direct”,则回退取“Direct”本身,并确保按时间顺序准确判断。

在用户行为分析中,识别客户首次触达渠道(First Touch)和最终转化前渠道(Last Non-Direct Touch)至关重要。但原始数据常包含大量“Direct”(直接访问)记录,这类渠道通常缺乏归因价值,需在提取首/末渠道时主动跳过——除非所有记录均为“Direct”,此时才保留它。

以下是一个健壮、可扩展的Pandas实现方案,无需显式for循环(避免低效迭代),而是基于向量化逻辑与分组聚合完成:

✅ 步骤详解

  1. 日期标准化与排序
    确保Date列转为datetime并按时间升序排列,这是正确识别“first”和“last”的前提:

    df["Date"] = pd.to_datetime(df["Date"], format="%m/%d/%y")  # 注意:示例数据为 M/D/Y 格式
    df = df.sort_values(["Customer ID", "Date"]).reset_index(drop=True)
  2. 构造智能过滤条件
    核心逻辑:对每个客户,仅保留非“Direct”记录;但若该客户所有记录都是“Direct”,则保留全部(以兜底):

    # 判断每个客户是否「全为 Direct」
    all_direct = df.groupby("Customer ID")["Channel"].transform(lambda x: (x == "Direct").all())
    
    # 过滤:保留「全为 Direct」的客户所有行,或「存在非 Direct」的客户的非 Direct 行
    mask = all_direct | (df["Channel"] != "Direct")
    df_filtered = df[mask].copy()
  3. 分组聚合获取首/末渠道
    在过滤后的数据上,按Customer ID分组,分别取first()和last()的Channel值:

    first_channel = (
        df_filtered.groupby("Customer ID", as_index=False)["Channel"]
        .first()
        .rename(columns={"Channel": "First Channel"})
    )
    
    last_channel = (
        df_filtered.groupby("Customer ID", as_index=False)["Channel"]
        .last()
        .rename(columns={"Channel": "Last Channel"})
    )
  4. 合并结果
    左连接两个聚合结果(确保客户ID完全对齐):

    result = pd.merge(first_channel, last_channel, on="Customer ID", how="left")
    print(result)

    输出:

       Customer ID First Channel Last Channel
    0            1         Email       Search
    1            2          Paid        Email
    2            3        Direct       Direct

⚠️ 注意事项

  • 日期格式必须匹配:示例中为"1/1/24"(月/日/年),请根据实际数据调整pd.to_datetime(..., format=...)参数(如"%Y-%m-%d"或自动推断infer_datetime_format=True)。
  • 稳定性保障:sort_values(["Customer ID", "Date"])确保同一客户内时间有序,避免因原始顺序混乱导致first/last误判。
  • 空值安全:本方案天然兼容缺失Channel值(可提前用df.dropna(subset=["Channel"])清洗)。
  • 性能提示:对百万级数据,此向量化方案比嵌套循环快10–100倍;如需进一步加速,可结合category类型编码Channel。

该方法兼顾业务逻辑严谨性与工程实践效率,是客户归因分析中处理“Direct”兜底场景的标准范式。

终于介绍完啦!小伙伴们,这篇关于《非直连渠道数据提取全攻略》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>