抖店自动回复软件开发教程与下载体验(.NET版)

转载请注明出处!

原文链接:https://blog.csdn.net/zgyulongfei/article/details/140960430


《抖店飞鸽客服自动回复软件开发教程与下载体验》

本文适合的读者为:

  1. 抖店(抖音小店)个体商家;
  2. 抖店店群商家(店群商家:指的是开了几十个抖店的商家);
  3. 想要开发一款抖店自动回复工具的技术人员/团队;
  4. 想学习浏览器自动回复技术的程序员;

省流介绍:

  1. 如果您是抖店商家,可以下载优化过的完善版工具体验,不用查看技术教程。(非商家不要下载!非商家不要下载!非商家不要下载!因为需要有店铺才能用)下载地址:https://www.yunpan.com/surl_y9HVpCnUCAD (提取码:9d35)
  2. 如果您是技术人员,可以细细查看文章,可在文末下载源代码。

目录

一、抖店飞鸽客服系统简介

二、自动回复的原理

三、开发环境与第三方类库

四、创建窗体应用

五、安装第三方JSON库

六、安装浏览器组件

七、软件主窗体设计

八、在主窗体加载抖店飞鸽客服网页

九、识别顾客发送的消息并自动回复

十、创建自动回复规则库 

十一、功能扩展

十二、源码下载


一、抖店飞鸽客服系统简介

抖店是抖音官方退出的购买产品的服务程序,商家在抖店平台上开店后需要与顾客沟通,抖店提供了飞鸽客服系统让商家与顾客进行有效沟通。

抖店飞鸽客服系统界面展示:

目前抖店飞鸽客服系统已经非常完善了,抖店官方也推出了【机器人】功能,帮助商家更高效地回复顾客。

对于咨询量不大的商家而言,平台自带的【机器人】功能已经足够使用了。

然而对于店铺数量多,日常咨询量大的商家来说,平台自带的【机器人】功能有时候会显得心有余而力不足。因为顾客给商家发送的客服消息,商家必须在3分钟内进行答复。当【机器人】遇到不会回答的消息时,而此时抖店商家非常繁忙无法及时给顾客答复消息时,会导致3分钟回复率降低。

什么是3分钟回复率?

顾客发送消息给商家后,商家需要在3分钟内答复顾客的咨询。3分钟回复率的计算方式是:在3分钟内回复的顾客咨询消息数,除以顾客咨询消息总数。快手平台要求这一比率不得低于80%,否则会影响店铺评分。

为了提高客服的3分钟回复率, 网店应该请足够多的人工客服人员来接待顾客的咨询。

然而,对于大部分利润微薄的抖店商家来说,请人工客服专员的成本非常高,网店的经营利润根本无法承担。

此时,要是网店主有一款客服自动回复工具,就可以减轻日常的工作量,减少店铺运营成本,进而提高网店的利润。

二、自动回复的原理

目前抖店飞鸽系统有电脑客户端软件、网页版客服、手机版几种形式。

本文的自动回复教程是对接飞鸽网页版客服系统,通过识别网页上的文字,匹配回复规则后再进行回复。

相当于是做一款飞鸽客服网页的浏览器插件,插件的主要功能是识别抖店飞鸽客服上顾客发送的咨询消息,然后匹配自定义的回复话术规则,再将匹配到的回复语发送给顾客。

三、开发环境与第三方类库

编程语言及框架:c# + WinForm

开发工具:Visual Studio 2017

应用程序运行环境:.Net Framework 4.5.2

Json库:Newtonsoft.Json v10.0.3

浏览器组件:CefSharp.WinForms v85.3.130

四、创建窗体应用

打开VS2017后,创建一个Windows窗体应用(.Net Framework)

目标框架选择:.NET Framework 4.5.2

应用名称填写:抖店自动回复软件

五、安装第三方JSON库

既然是开发一款自动回复工具,那么就必须要有一个自动回复规则库 ,来保存顾客咨询问题的关键词与答复语之间的对应关系。

当顾客咨询时,软件去规则库中查找新消息是否包含规则中的关键词,关键词匹配后,将关键词对应的答复语发送给顾客。

自动回复规则库应该由商家根据店铺的主营商品、商品规格、发货时间、发货地点等情况合理设置,因此需要一个本地数据库。本地数据库一般使用SQLite,它是一款免费的轻量级数据库。

由于本文作为开发范例,主要目的是让读者方便理解与实践,本教程的规则库采用Json格式保存在文件中,因此需要用到第三方JSON库Newtonsoft.Json。

JSON库安装方法:点击VS2017菜单【项目】-【管理NuGet程序包】

切换菜单为【浏览】,然后搜索:Newtonsoft.Json,下拉框中选择v10.0.3版本并安装

六、安装浏览器组件

由于需要对接抖店飞鸽网页版客服,因此需要一个浏览器组件来加载和显示飞鸽客服网页,之后再通过操作浏览器组件来实现识别客服文字以及自动回复。

在Winform中添加一个浏览器控件,现在一般使用第三方开源组件CefSharp.WinForms。

在NuGet中搜索CefSharp.Winfoms,选择v85.3.130版本后安装。

由于CefSharp不支持以Any CPU模式运行程序,所以需要在配置管理器中指定运行平台为x86或x64。调整后的截图如下:

七、软件主窗体设计

软件主窗体需要显示一个【抖店飞鸽客服网页】,以及一些功能性按钮【设置回复规则、开启自动回复、关闭自动回复】。

浏览器组件嵌套在一个Dock.Fill的Panel中,功能区使用MenuStrip组件并创建菜单项。

八、在主窗体加载抖店飞鸽客服网页

在项目上新建CefHelper类,用来初始化CefSharp.Winforms组件的初始化配置。

CefHelper类中的代码如下:

class CefHelper
    {
        public static readonly string WebCachePath = Application.StartupPath + "\\cache";

        public static void InitCef()
        {
            Cef.EnableHighDPISupport();
            CefSettings settings = new CefSettings
            {
                Locale = "zh-CN",
                AcceptLanguageList = "zh-CN,zh;q=0.9",
                UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.121 Safari/537.36",
                PersistUserPreferences = true,
                PersistSessionCookies = true,
                RootCachePath = WebCachePath
            };
            settings.CefCommandLineArgs.Add("disable-features", "WebRtcHideLocalIpsWithMdns");
            Cef.Initialize(settings);
        }
    }

接着在应用程序入口点调用CefSharp的初始化代码:

CefSharp初始化完毕之后,才能创建浏览器组件。

创建浏览器组件不能用常规拖放控件的方式,必须使用代码创建,浏览器组件类名为ChromiumWebBrowser。

创建方法:在主窗体Form1中编写创建方法CreateWebBrowser()来创建一个ChromiumWebBrowser控件,并将其放在主窗体的Panel中。

   /// <summary>
        /// 创建飞鸽客服浏览器
        /// </summary>
        /// <returns></returns>
        private ChromiumWebBrowser CreateFeiGeWebBrowser()
        {
            //浏览器启动时,初始化显示的飞鸽客服网址
            string initUrl = "https://im.jinritemai.com/pc_seller_v2/main/workspace";
            ChromiumWebBrowser fgBrowser = new ChromiumWebBrowser(initUrl)
            {
                RequestContext = new RequestContext(new RequestContextSettings()
                {
                    PersistSessionCookies = true,
                    PersistUserPreferences = true,
                    CachePath = CefHelper.WebCachePath
                })
            };

            //将浏览器添加到Panel
            panel_Browser.Controls.Add(fgBrowser);

            //
            return fgBrowser;
        }

在主窗体构造函数中调用此方法:

运行程序后,效果如下:

飞鸽客服网页已经打开,先登录抖店店铺方便后续操作!

九、识别顾客发送的消息并自动回复

为了获取用户发送的消息,需要使用到JavaScript技术,利用js代码获取网页元素中的内容。

抖店飞鸽客服会把新的咨询顾客放在【当前会话】中。

 要识别是否有新消息,需要识别顾客行上是否有显示时间,这个时间表示顾客发信息了多长时间。

由于抖店飞鸽网页中的元素class都是乱码,无法直接通过getElementsByClassName来定位到元素:

因此需要根据文字内容来识别,获取所有同一种元素标签的集合,然后循环遍历这个标签集合,去找到其中的元素包含:时、分、秒的关键词,进而定位到元素。

检测到当前会话列表含有未回复的顾客时,点击顾客加载对话内容,参考代码如下:

var doms = document.getElementsByClassName('i-icon i-icon-icon-collection-solid');
for (var i = 0; i < doms.length; ++i) {
    var d = doms[i];
    var f1 = d.parentElement;
    if (f1) {
        var f2 = f1.parentElement;
        if (f2) {
            var f3 = f2.parentElement;
            if (f3) {
                var timeSpan = f3.textContent.trim();
                if (timeSpan.indexOf('秒') >= 0 || timeSpan.indexOf('分') >= 0 || timeSpan.indexOf('时') >= 0) {
                    f3.click();
                    break;
                }
            }
        }
    }
}

点击完顾客后,获取顾客发送的最后一条信息,自动回复仅匹配最后一条信息即可!

用js编写如下代码即可获取到最后一条信息:

获取到顾客最后一条信息之后,去自动回复规则库中匹配回复语,然后将回复语填充到文本输入框中发送给顾客(规则库如何设计在后面章节中说明)。

假设回复语为:ok

那么在文本框中填充文字的js代码为:

document.getElementsByTagName('textarea')[0].value='ok'

填充后效果为:

但是点击【发送】按钮后,系统却提示:

明明已经在文本框中填充了【ok】文字了,为什么发送的时候却提示文本为空呢?

原因是网页系统监听了文本框事件,只有打字进去才会识别已输入,设置元素的value无效。

那么如何解决呢?

可以将文字【ok】复制到剪切板,然后在将剪切板的文字粘贴到textarea中即可。此种方法需要占用剪切板,实现效果不是很好。也有不占用剪切板,更高效且简单的方法,感兴趣的可以与作者联系。

整个自动回复过程为:

  1. 检测新消息
  2. 获取顾客发送的最后一条消息
  3. 填充回复语
  4. 点击发送

将js代码封装到c#中,由c#调用js代码。编写JsHelper类:

JsHelper内编写几个静态方法供调用:

  1. GetUnreplyMsgCount
  2. GetCustomerLastAskMsg
  3. InputReplyMsg
  4. ClickSendButton
  5. ClickFirstCustomer

具体源代码可以在文末下载!

接着在主窗体Form1中创建一个线程,每隔5秒定时检测一次是否有未回复的消息,如果有消息就去回复一次。

private void StartAutoReplyTask(ChromiumWebBrowser b)
        {
            Task.Factory.StartNew(() =>
            {
                //等待一会儿再开始执行轮询线程
                Thread.Sleep(2000);

                //循环检测消息
                while (true)
                {
                    if (OpenAutoReplyTask)
                    {
                        //检测是否有新消息
                        while (JsHelper.GetUnreplyMsgCount(b) > 0)
                        {
                            //点击第一个顾客
                            JsHelper.ClickFirstCustomer(b);

                            //等待聊天对话加载
                            Thread.Sleep(1000);

                            //获取此顾客最后一条消息
                            string lastMsg = JsHelper.GetCustomerLastAskMsg(b);

                            //根据顾客消息匹配回复语
                            string replyMsg = GetReplyMsg(lastMsg);

                            //在聊天文本框中填充回复语
                            JsHelper.InputReplyMsg(b, replyMsg);

                            //点击发送按钮
                            JsHelper.ClickSendButton(b);

                            //回复完每一个顾客都等几秒,防止页面反应慢,这个顾客还在【请在3分钟内回复】菜单内
                            Thread.Sleep(3000);
                        }
                    }

                    //执行完一遍流程后,等待5秒再继续执行下一轮
                    Thread.Sleep(5000);
                }
            }, TaskCreationOptions.LongRunning);
        }

上面代码中的方法GetReplyMsg()是去规则库中获取匹配到的回复语,将在下一节说明。

十、创建自动回复规则库 

为了能让自动回复软件根据顾客的问题回答不同的回复语,必须创建一个回复规则库。

为了便于理解与实践,本文采用Json文件存储规则库。

新建类Rules,用来存储关键词与回复语的映射关系。

    /// <summary>
    /// 单条规则
    /// </summary>
    class RuleItem
    {
        /// <summary>
        /// 规则关键词
        /// </summary>
        public string Keyword { get; set; }

        /// <summary>
        /// 关键词匹配的回复语
        /// </summary>
        public string ReplyMsg { get; set; }
    }

创建RuleHelper类,用来操作规则库(增、删、改、查)

Helper类中的方法:

  1. SaveJsonToFile
  2. AddRule
  3. FindRuleReply

在哪个地方做增删改查?

需要创建一个规则库窗口FormRules,然后在窗口上进行操作

在按钮添加事件,增加规则即可。

运行软件后,打开规则窗体添加规则效果:

规则文件rules.json内容:

发消息测试:

运行效果说明软件能正常地根据顾客的消息回复对应的答复语。

十一、功能扩展

这个抖店飞鸽自动回复软件只是一个简单的样例,距离完善还有很大的距离。

功能可扩展的地方还有很多,如:

  1. 支持多关键词匹配
  2. 支持完全匹配与包含匹配
  3. 规则库可修改、删除
  4. 能保存历史回复记录
  5. 能店铺多开同时回复
  6. 能根据不同店铺回复不同话术
  7. ……
  8. ……

十二、源码下载

CSDN下载地址:https://download.csdn.net/download/zgyulongfei/89623129

### 回答1: Python千牛自动回复软件开发是利用Python语言开发的一种自动回复工具,用于在千牛平台进行自动回复。千牛是一款阿里巴巴集团开发的一款电商管理软件,提供了多种功能,包括店铺管理、订单管理、客服管理等。 开发Python千牛自动回复软件主要涉及到两个方面的内容。首先,需要了解千牛平台的接口和数据结构,以便可以通过接口进行消息的发送和接收。其次,需要使用Python编程语言进行逻辑的实现和具体的功能开发。 在开发过程中,可以使用Python的第三方库进行开发,例如使用requests库进行网络请求和数据传输,使用beautifulsoup库进行网页解析和信息提取。通过分析千牛平台的网页结构和数据流程,可以实现自动登录、发送消息、获取消息等功能。 开发完毕后,可以将Python千牛自动回复软件部署到服务器上,保持运行状态,定期检查并自动回复用户的消息。通过设置关键词、预设回答等功能,可以根据用户发送的消息进行智能化回复,提高客户的满意度和体验。 总之,Python千牛自动回复软件开发可以极大地提高客服工作的效率和准确性,通过自动回复来处理大量的问题,节省人力成本和时间。同时,通过使用Python语言进行开发,可以快速实现功能,灵活适配千牛平台的需求。 ### 回答2: Python千牛自动回复软件开发可以通过使用Python编程语言来创建一个能够自动回复千牛消息的软件。千牛是一款电商客服管理软件,它与淘宝、天猫等电商平台的聊天系统连接,用于管理和处理订单、客户咨询和售后服务等。 首先,我们需要使用Python的相关库,例如selenium和pyautogui,来模拟人工操作千牛客服聊天窗口。通过这些库,我们可以编写程序来自动登录千牛、获取聊天消息、发送回复消息等。 其次,开发过程中,我们需要编写一些逻辑来处理不同的消息情况。可以使用条件语句判断收到的消息内容,然后选择相应的回复内容进行回复。例如,如果收到的消息是客户询问物流信息,我们可以调用相应的接口获取物流信息并回复给客户。 另外,为了提高回复效率,我们可以使用自然语言处理(NLP)的技术来进行消息的自动分类和处理。通过训练一个机器学习模型来识别不同类型的消息,可以更快速地准确回复客户。 最后,我们还可以添加一些额外的功能来增强软件的实用性。例如,可以实现关键词自动回复,让软件能够根据预先设置的关键词自动回复相应内容。或者可以将一些常见问题和答案保存在数据库中,当收到相应问题时,软件可以自动从数据库中获取答案并回复客户。 综上所述,Python千牛自动回复软件开发需要使用Python编程语言和相关库,编写程序逻辑来模拟人工操作千牛聊天窗口,处理不同的消息情况,并可以根据需要添加额外功能来增强实用性。 ### 回答3: Python千牛自动回复软件开发是利用Python编程语言开发的一种应用程序,旨在实现对千牛平台进行自动化回复的功能。 首先,开发过程需要先了解千牛平台的接口文档和使用规则,了解千牛平台的功能和限制。然后使用Python编写代码,实现与千牛平台的交互。 在开发过程中,需要使用Python的相关模块和库,如requests模块用于发送网络请求、json模块用于处理数据、selenium模块用于模拟浏览器操作等。 开发过程中涉及的主要功能包括: 1. 用户登录和权限认证:使用千牛平台提供的API,实现用户登录和权限认证的功能,确保只有授权的用户才能使用自动回复软件。 2. 消息接收:通过监听千牛平台的消息接口,实时获取到收到的消息。 3. 消息处理和回复:对接收到的消息进行处理和分析,判断需要回复的类型和内容,并调用千牛平台的API进行消息回复操作。 4. 定时任务:可设置定时任务,定时执行特定的操作,如发送定时提醒消息、更新自动回复的规则等。 5. 数据存储和分析:将收到的消息和回复记录存储到数据库中,方便后续的数据分析和统计。 开发过程中需要注意保护用户隐私和数据安全,确保系统的稳定性和可靠性。 总之,Python千牛自动回复软件开发是一项利用Python编程语言进行的开发工作,通过调用千牛平台的API实现对千牛平台的自动化回复功能,能够提高处理效率,提升用户体验
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

清缓

您的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值