完成RPA类产品研发需要解决哪些技术问题

密密麻麻
• 阅读 252

放在讨论前

这里谈论RPA类产品技术前,还是要说到一些背景知识,也方便入门的朋友便于理解为什么要解决这些技术问题 首先:对于RPA类产品,它所提供的解决方案并不是范范的针对某个具体业务场景,它所需要解决的问题相对比较广。

常规理解

举个例子来说: 有人说RPA感觉就是网络爬虫---其实这个理解是希望RPA产品能解决基于BS类Web应用的数据爬取 有人说RPA感觉就是Excel的宏---其实这个理解是觉得RPA可以自由的像Excel的宏一样,可以任意操作Office内数据 有人说RPA感觉就是原来的鼠标精灵---其实这个理解是觉得RPA就是可以设定一些规则自由点击电脑屏幕上想要点击的位置 等等等等 其实这些基本想法都是RPA产品应该包含的范畴,但是RPA产品如果只是上面说的期待的例子那就太少太少了。

设计理解

还是就着上面的例子先扩展说下:

例一分析

先简单讨论下第一个例子,如果完整说来,我们所面对的BS类Web应用现在在市场上其实有很多细分 首先先说运行环境浏览器,从B端应用市场上来看使用面最广的还是Chrome类(包括现在Chrome内核的Edge,同样兼容的Firefox)---我这里就统称为【现代浏览器】吧,以及目前依然在传统金融领域持续使用的IE,基于这个应用基本环境的考量,RPA起码应该可以满足在【现代浏览器】及IE上都可以进行数据的有效爬取 另外从业务过程上来说,除了我们从页面上读取信息(也就是所说的爬取信息,以及爬取属性)还有更重要的部分就是---写入,这个【写入】的表述比较有些粗糙,其实准确的表述,应该包括信息写入,下拉选择,Checkbox选择,多项选择,功能点击(脚本点击,模拟点击)浏览器导航,刷新等等一系列在业务使用中的动作 所以这么看来,如果要达成产品级别的BS数据爬取,可能需要解决的问题还是很多的

例二分析

同样,我们再聊下第二个例子,从第二个例子中可以看到的含义,字面上:是能够在业务环境的载体(Excel)中自我定制业务逻辑,而且并不破坏原来的环境(Excel),这里去掉括号内的文字,其实针对这个例子的就是一个相对比较有广泛应用高度的定义了,也就是RPA要有足够的整合能力,当然这个整合可以是自建服务的整合,也可以是整合第三方有效服务的能力,这里绝对不可能局限在例子中的Excel上,可以向外延展到Office整个系列,包括Excel,Word,Outlook,PPT,PDF等等,以及跳出办公Office外的各种数据库等,各种常用文本类型Txt,CSV等,甚至延展到PowerShell,SSH,以及任意的自定义程序脚本的整合等等等等....当然这里到底可以整合哪些,完全取决于你可以想象到的RPA应用场景中可能面对的业务对象是什么....哈哈,听起来就像是取决于你的想象力,是不是突然觉得很有想象空间了

例三分析

那这里要聊的第三个例子和第一个有点像,但是从应用背景来看,的确是和第一个有实质区别的,这个例子中面对的场景,我们把它归类为RPA产品支持CS类应用,一旦上升到产品层面讨论CS应用,就不能只在【鼠标精灵】上讨论这个问题了,我们还是要仔细从CS应用类别详细分类来思考了 还是首先说说运行环境:在国内我们目前面对的绝大多数桌面系统还是已Windows系列为主了(当然有部分有Mac或是其他Linux内核桌面系统,这是另一个大分类,目前先部讨论),在目前主流的桌面系统中,具体到需要解决的RPA场景,分类依据主要还是以GUI的大类别来区分,其实这里在市面上类别还是挺多的,有基于C++多种框架开发,有基于C#开发的,还有基于Java,基于Go或Python等,所以回到最开始来满足【鼠标精灵】的想法来做RPA产品,那上面这些GUI场景就成了必须要解决的技术问题 同样也脱不开业务过程的思考,毕竟 包含规则的【鼠标精灵】要想涵盖绝大多数业务过程是做不到的,所以接下来的 Gui上信息读取,属性读取,信息写入,各类选择,以及表格对象识别等等,都是要构建一个完整RPA产品必须要面对并且要解决的问题

常规理解之外的设计

当然上面聊了这些,也不能代表这些就是一个完整RPA产品的全貌,因为上面三个大众基本认识都是在聊RPA中A(Automation)的部分,其实一个完整的RPA产品除了咱们讲到的三个基本理解外还有一个核心的问题也需要拿出来解决,就是RPA中的P部分(Process),也就是除了上面提到的场景识别外,还需要有个完整的流程控制部分,专门用于快速定义业务流程,来满足复杂的业务过程控制

其实这里基本上已经比较完整了,但是我估计肯定有人要说还有一个重要的部分,就是管理控制部分 的确没错,通常意义上的控制台还是有实际用途的,不过相较而言,这个部分在技术上的难度和RPA本身没有太大的相关性,所以不在提及,如果后续有感兴趣的朋友,我也可以把我们产品的控制中心的设计思路分享下

本篇总结

本篇从几个大众基本理解的角度,粗略的讨论了RPA产品应该如何去定义 目前看来缺少很多细节,大家可以移步,下一节【一个基本的RPA类产品应该具备的能力】,这里将会展示一个基本RPA产品应该具备的绝大部分能力,欢迎大家批评指正

点赞
收藏
评论区
推荐文章
密密麻麻 密密麻麻
1年前
一个基本的RPA类产品应该具备的能力
一个基本的RPA类产品应该具备的能力详解
Wesley13 Wesley13
2年前
RPA有哪些网络风险?如何通过RPA提升组织安全性
RPA有哪些网络风险?如何通过RPA提升组织安全性随着RPA市场的活人,在当前商业环境中,RPA已成为企业实现数字化转型的重要组成部分。由于RPA机器人的跨平台、跨系统的特性,其可普遍应用于企业各项业务中。所以,RPA项目既应通过保护机器人平台来应对网络风险,也应利用机器人技术来执行更有效、更高效的网络操作。组织必须建立对其RPA平台的信任
Wesley13 Wesley13
2年前
PHP程序员的技术成长规划 第三阶段:高级阶段
第三阶段:高级阶段(高级PHP程序员)重点:除了基本的LNMP程序,还能够在某个方向或领域有深入学习。(纵深维度发展)目标:除了能够完成基本的PHP业务开发,还能够解决大部分深入复杂的技术问题,并且可以独立设计完成中大型的系统设计和开发工作;自己能够独立hold深入某个技术方向,在这块比较专业。(比如在MySQL、Ngi
Wesley13 Wesley13
2年前
ES某节点CPU增长至100%的诡异问题
这是一个从事发到目前为止我没有从根本上解决的技术问题,也是我心中的一个非常大的疑惑。写于:20200614周日,下午14:00问题已解决,解决过程和方案可以看文章最末尾,解决方案写于2020062015:26问题一:2020年6月4号上午10点左右(高峰期),A集群某节点,我们姑且称之为37号节点,CPU增长至100%
Stella981 Stella981
2年前
Linux应急响应(二):捕捉短连接
0x00前言​短连接(shortconnnection)是相对于长连接而言的概念,指的是在数据传送过程中,只在需要发送数据时,才去建立一个连接,数据发送完成后,则断开此连接,即每次连接只完成一项业务的发送。在系统维护中,一般很难去察觉,需要借助网络安全设备或者抓包分析,才能够去发现。0x01应急场景​
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
京东云开发者 京东云开发者
5个月前
DDD技术方案落地实践 | 京东云技术团队
1\.引言从接触领域驱动设计的初学阶段,到实现一个旧系统改造到DDD模型,再到按DDD规范落地的3个的项目。对于领域驱动模型设计研发,从开始的各种疑惑到吸收各种先进的理念,目前在技术实施这一块已经基本比较成熟。在既往经验中总结了一些在开发中遇到的技术问题和
十月飞翔 十月飞翔
1年前
给集群其他节点加计算机点标签
参加如下标签添加项:计算类产品标签设计具体步骤和指令:查看目前计算节点标签的机器有哪些:添加label:kubectllabelnodesc0410ow0js6779ecs/configschedulabletruekubectllabelnodesc0410ow0js6779ecs/pool
王吉伟频道 王吉伟频道
1年前
聊聊RPA的易用性:从“人人可用”到端到端全生命周期
聊聊RPA的易用性:从“人人可用”到端到端全生命周期分别从C端与B端,聊聊RPA的易用性RPA易用性之我见:C端人人可用,B端全生命周期文/王吉伟对于RPA发展的未来宏图,很多厂商都有一个RPA“人人可用”的愿景。而要实现RPA的人人可用,最重要的一点就是要持续提升RPA产品的易用性。易用性是可用性的一个重要方面,指的是产品对用户来说易于学习和使用、减轻记忆
王吉伟频道 王吉伟频道
1年前
RPA云电脑,让RPA开箱即用算力无限?
独家消息:阿里云悄然推出RPA云电脑,已与多家RPA厂商开放合作RPA云电脑,让RPA开箱即用算力无限?文/王吉伟这几天,王吉伟频道通过业内人士获得独家消息,阿里云近期推出了一个名为「RPA云电脑」的项目,由一直低调但备受关注的无影架构团队研发,已有包括实在智能、影刀等多家RPA头部厂商与之产品技术对接。从资料来看,RPA云电脑具备自动登陆注册机器人、一键自
密密麻麻
密密麻麻
Lv1
男儿少为客,不辨是他乡。
文章
2
粉丝
2
获赞
4