做京东评论分析系统 3 年,京东评论数据解析

简介: 解析京东评论时,因忽略“追评”字段(after_comments)及图片嵌套结构,导致30%差评漏预警。主评与追评需分别提取,结合评分、带图、脱敏昵称等处理,完善情感判断逻辑,避免商家错失回复时机,影响店铺评分。

数据解析陷阱:漏了追评,商家差评预警漏了 30% 的差评

系统上线后第二周,商家反馈:“昨天的 12 条差评,系统只预警了 8 条!” 排查发现,京东评论的返回结果藏着 “双字段陷阱”——主评存在comments字段,追评(追加评论)存在after_comments字段,我只解析了comments,完全漏掉了追评里的差评:比如用户买了商品 3 天后追加的 “质量差,掉漆”,系统没抓到,导致商家没及时回复,店铺动态评分掉了 0.2 分。

更坑的是,带图评论的图片 URL 藏在imagesurl字段里,且部分追评的images是嵌套结构,直接取值会报 KeyError;另外京东会对用户昵称脱敏(比如 “张 **”),如果直接展示会出现乱码。我连夜重写的评论解析函数,专门整合主评、追评、带图评论和情感判断:

企业微信截图_17663873711409.png

python实例

jd.review/[测试调试]

```items": {
"real_total_results": 500000,
"total_results": 500000,
"page_size": 10,
"page": "1",
"item": [
{
"rate_content": "大品牌质量好使用方便价格便宜",
"rate_date": "2025-12-22 14:10:35",
"pics": [],
"rate_id": "103553730157088578",
"guid": "T6NdPMJ0j58tdR-BW66QxXiJ",
"score": 5,
"display_user_nick": "xujian1966",
"auction_sku": "BM1(S2);",
"add_feedback": null
},
{
"rate_content": "这是第二次回购确实有蛮实用给五星好评",
"rate_date": "2025-12-22 14:04:22",
"pics": [
"jfs/t1/375305/12/20041/261755/6948df61F9fd28fd4/00a94ecaf014c703.jpg",
"jfs/t1/376768/4/18439/269304/6948df65F5fed58df/00a94ecaf00b6fbc.jpg",
"jfs/t1/379944/35/12289/321964/6948df64Fe0093753/00a94ecaf06eea35.jpg",
"jfs/t1/373946/31/20633/335073/6948df62Ff02f42fe/00a94ecaf0921005.jpg"
],
"rate_id": "103543710155619542",
"guid": "T6NdPMN0j50tdR-DXaeRxXuD",
"score": 5,
"display_user_nick": "jd_152740bfh",
"auction_sku": "BM1(S2);",
"add_feedback": null
},
{
"rate_content": "非常好",
"rate_date": "2025-12-22 12:58:29",
"pics": [],
"rate_id": "103541160162348180",
"guid": "T6NdPMN2iZotdRyEWKKQwXeB",
"score": 5,
"display_user_nick": "jd_8hw1mybnt7ic1p",
"auction_sku": "BM1(S2);",
"add_feedback": null
},
{
"rate_content": "好用的,经常回购,下次继续回购,推荐",
"rate_date": "2025-12-22 12:31:51",
"pics": [],
"rate_id": "103045080228559127",
"guid": "T6NdOcNyiJQtdhiOXqORwX2G",
"score": 5,
"display_user_nick": "扶摇公子Kiss",
"auction_sku": "BM1(S2);",
"add_feedback": null
},





运行

def parse_jd_comments(comment_data):
"""
解析京东评论:整合主评/追评、带图评论、情感判断
:param comment_data: 接口返回的评论数据
"""
all_comments = []

# 1. 处理主评(必存在)
main_comments = comment_data.get("result", {}).get("comments", [])
for main in main_comments:
    # 提取带图评论的图片URL(无图则返回空列表)
    comment_images = [img.get("url") for img in main.get("images", []) if img.get("url")]
    # 情感判断:1-2分=差评,3分=中评,4-5分=好评
    emotion = "差评" if main.get("score", 3) <=2 else "中评" if main.get("score")==3 else "好评"
    all_comments.append({
        "comment_id": main.get("id"),
        "user_nick": main.get("nickname", "匿名用户"),  # 脱敏昵称,如“李**”
        "emotion": emotion,
        "content": main.get("content", "").replace("\n", " "),  # 处理换行符
        "images": comment_images,
        "create_time": main.get("create_time"),
        "comment_type": "主评"
    })

# 2. 处理追评(部分评论无追评,需判断)
after_comments = comment_data.get("result", {}).get("after_comments", [])
for after in after_comments:
    after_images = [img.get("url") for img in after.get("images", []) if img.get("url")]
    emotion = "差评" if after.get("score", 3) <=2 else "中评" if after.get("score")==3 else "好评"
    all_comments.append({
        "comment_id": after.get("id"),
        "user_nick": after.get("nickname", "匿名用户"),
        "emotion": emotion,
        "content": after.get("content", "").replace("\n", " "),
        "images": after_images,
        "create_time": after.get("create_time"),
        "comment_type": "追评"
    })

# 按评论时间倒序排序(最新评论在前)
return sorted(all_comments, key=lambda x: x["create_time"], reverse=True)

示例调用

raw_comment = {
"result": {
"comments": [
{"id": "12345", "nickname": "张", "score": 1, "content": "质量差", "images": [{"url": "xxx.jpg"}], "create_time": "2025-12-20 10:00"}
],
"after_comments": [
{"id": "12346", "nickname": "李
", "score": 1, "content": "追加:掉漆了", "images": [], "create_time": "2025-12-23 15:00"}
]
}
}
parsed_comments = parse_jd_comments(raw_comment)
print(f"共解析{len(parsed_comments)}条评论,其中{len([c for c in parsed_comments if c['emotion']=='差评'])}条差
```

相关文章
|
5天前
|
数据采集 人工智能 安全
|
14天前
|
云安全 监控 安全
|
6天前
|
自然语言处理 API
万相 Wan2.6 全新升级发布!人人都能当导演的时代来了
通义万相2.6全新升级,支持文生图、图生视频、文生视频,打造电影级创作体验。智能分镜、角色扮演、音画同步,让创意一键成片,大众也能轻松制作高质量短视频。
1180 152
|
19天前
|
机器学习/深度学习 人工智能 自然语言处理
Z-Image:冲击体验上限的下一代图像生成模型
通义实验室推出全新文生图模型Z-Image,以6B参数实现“快、稳、轻、准”突破。Turbo版本仅需8步亚秒级生成,支持16GB显存设备,中英双语理解与文字渲染尤为出色,真实感和美学表现媲美国际顶尖模型,被誉为“最值得关注的开源生图模型之一”。
1835 9
|
11天前
|
人工智能 自然语言处理 API
一句话生成拓扑图!AI+Draw.io 封神开源组合,工具让你的效率爆炸
一句话生成拓扑图!next-ai-draw-io 结合 AI 与 Draw.io,通过自然语言秒出架构图,支持私有部署、免费大模型接口,彻底解放生产力,绘图效率直接爆炸。
747 152
|
8天前
|
SQL 自然语言处理 调度
Agent Skills 的一次工程实践
**本文采用 Agent Skills 实现整体智能体**,开发框架采用 AgentScope,模型使用 **qwen3-max**。Agent Skills 是 Anthropic 新推出的一种有别于mcp server的一种开发方式,用于为 AI **引入可共享的专业技能**。经验封装到**可发现、可复用的能力单元**中,每个技能以文件夹形式存在,包含特定任务的指导性说明(SKILL.md 文件)、脚本代码和资源等 。大模型可以根据需要动态加载这些技能,从而扩展自身的功能。目前不少国内外的一些框架也开始支持此种的开发方式,详细介绍如下。
549 5
|
13天前
|
人工智能 安全 前端开发
AgentScope Java v1.0 发布,让 Java 开发者轻松构建企业级 Agentic 应用
AgentScope 重磅发布 Java 版本,拥抱企业开发主流技术栈。
689 14