Bootstrap

Uipath、BluePrism、AA产品对比之设计器篇

版本说明:

Uipath V2018.3.2,BluePrism V6.3,Automation Anywhere 11.2

 

原文地址:

https://mp.weixin.qq.com/s?__biz=Mzg4NTA1NTY1NA==&mid=2247483825&idx=1&sn=51ca81697434e52f6206aec0b9581480&chksm=cfaf8878f8d8016e47d20ca23b97a4fb87fcdedde2c198f2c15720ba473004cd50d1def29272&token=694250830&lang=zh_CN#rd

Uipath (UP)

 

  • 新建

  1. UP的产品思路是从易于开发者安装和使用开始,本质是以自建工程起步的单机版开发工具,尽管目前版本的名字已经从NewProject改名成NewProcess ,但本质上每个人新建的还是一个工程文件。

  2.  熟悉Visio Studio 等任何一款软件开发工具的朋友就会对工程的概念很熟悉 , 如果有人在CSDN上分享成果,大家更想要的肯定是完整的开发工程包。

  3.  特点:单机本地工程文件,流程项目协同/版本控制,开发者权限/审计,代码安全等需要额外的管理方法和工具才可以实现 ; 但最大优势是,安装部署简便,再加上Uipath的大市场战略,所以国内知道UP,玩UP的人数量上是最多的。

 

  • 流程设计

 

UP的设计器画面总给人一种无法看清流程全貌的感觉。

由于产品的历史原因和用户习惯使然,UP设计器还是主要在Main窗体里面套各种Sequence (序列,方框框)为主。

假设有如下需求已经通过Visio画出流程图,在UP中的实现参见下图:

如果不展开结构,似乎我们只看到了 Do While 和 If判断,那么我们就展开结构。

展开后的流程看起来累不累? 熟悉UP的玩家说,“还好啊” 。但问题是,这个需求如此简单,流程设计逻辑就看起来那么烦人了,那复杂的长流程+很多逻辑分支的情况呢 ?

 

为了解决Sequence的很多缺点,UP推出了 FlowChart Activity。

UP推出FlowChart Activity 就是想以画布设计的方式部分解决流程设计的缺点

但从FlowChart只是UP的一个Activity组件就大概能明白目前UP对FlowChart的定位。我不确定未来UP是否会强化FlowChart组件,让其成为内置默认设计框架,而Sequence 变成一个Activity 。 如果到了那一天, UP或许更加强大了。 (还有一个很重要原因想必是很多UP玩家习惯了 Sequence,而不愿意去适应FlowChart)

 

  • 元素抓取

     

一款RPA工具是否强大,跟能抓到什么级别的元素还是蛮正相关的。不得不承认UP的元素抓取工具还是蛮强的。 点击 Indicate Element后 ,UP首先是以智能识别模式根据鼠标移动的位置自行判断元素类型和适配的方式。

如果是抓网页,默认会选择HTML方式去分析。有一些特殊情况可以考虑 UIA方式,实在无法识别就用区域模式去靠图片识别。

 

测试题是:  mail.qq.com    点击- 账号密码登陆按钮

UP可以抓到,Selector结构如下

这个测试其实不难,只是抛砖引玉 ,不妨在考虑下以下场景:

SAP/Oralce EBS /用友ERP 元素抓取能力如何

特殊网页数据Table抓取能力如何,控件怎么处理

特殊的Java开发程序抓取能力如何

甚至Mainframe程序是否可以读到模拟器中信息

 

某一项流程能不能被完美自动化,往往是由能否顺利抓取到元素,读取元素信息所决定的。 

 

  • 可复用性

     

流程设计的基础模块功能可复用性的高低,是否可以方便其他人拿来就用,直接决定了项目开发效率和周期。

 

UP通过Add Folder 可以将一些通用性Library xaml文件导入到系统中(严格的讲只是被系统认到,并没有导入到系统的概念)。识别后也可以通过类似操作Activity的方式去调用这些共用。

 

但这些单独的文件,在项目协同,传参等方面还是有一些问题的。

BluePrism(BP)

 

  • 新建

 

区别于UP,BP的设计思路一开始就是定位企业级甚至金融级的RPA平台。

所以在已经部署有RPA的环境中,你想新建一个自动化Robot ,对不起你得先有账号。每一个开发都是经过认证并且行为可追溯的。

BP通过新建Process ,来定义流程。 Process流程可以有很多Page页,便于梳理流程结构 ;Process可以调用Object实现基础功能模块 ;Process也可以调用Process。

 

  • 流程设计

 

BP的设计画布更让有人设计的感觉。

BP的流程设计主要有两个维度:

第一个维度是Object ,

Object用来搞定跟各种第三方系统打交道的模型。Object 中有一个重要模块叫 Applicaiton Modeller ,通过这个适配器BP会协助开发者帮助建立BP与应用系统联系。

第二个维度是Process ,

只有Process才是可以被Publish发布到Control Room,以“正规”的方式去执行流程任务。 而Object仅仅可以在设计器Studio中运行 。

 

 

回到之前那个样例,如果在BP中实现设计,参见如下图

不得不佩服BP把设计器Studio做的非常好 。

很多场合如果是用BP流程设计开发,可以直接贴到项目的各种设计文档中。

 

  • 元素抓取

BP的元素抓取能力非常强,而且支持很多模式,混合使用各种不同模式可以有更佳的效果。

HTML Mode

Win32 Mode

UI Automation Mode

Accessibility Mode

Region Mode

 

BP可以轻松抓取账号密码登陆这个Tab Bar ,而且能对元素进行深入分析,勾选匹配项。

BP应该是目前唯一一家可以对市场上主流的Mainframe模拟器进行解析,读模拟器中数据,直接写数据到模拟器中。 

 

 

  • 可复用性

BP VBO(Visiual Business Object 可视化业务对象)可以极大的提高流程开发的效率。 在面对比较复杂的流程的时候,可以分别由不同的开发人员设计不同的VBO对接不同系统 ,如果是在同一个开发平台 ,其他人可以直接在系统中调用别人已经开发好的VBO对象。如果不在同一个项目,也可以通过将VBO导出成XML文件的方式与别人共享。

BP项目在设计阶段,如何合理的设计不同的Object VBO对象,对项目进程会有较大的影响。 

 

Automation Anywhere(AA)

 

  • 新建

与BP类似,AA也是企业级部署的RPA平台。

没有单机运行的设计器,要部署了完整的整套系统才可以登陆AA平台。AA在对外宣传的时候号称有非常强的高可用性系统架构,由于是设计器专题这些也就不展开了。

AA新建Workbench,就是基于Task的维度。

  • 流程设计

 

AA流程的核心是TASK,通过设计编写TASK来完成特定业务流程,或者再通过Workflow去调用TASK。当然TASK本身也可以调用TASK。

TASK里面利用很多很多Commands或者MetaBots,来组成具体的任务流。

 

 

 

原文地址:

https://mp.weixin.qq.com/s?__biz=Mzg4NTA1NTY1NA==&mid=2247483825&idx=1&sn=51ca81697434e52f6206aec0b9581480&chksm=cfaf8878f8d8016e47d20ca23b97a4fb87fcdedde2c198f2c15720ba473004cd50d1def29272&token=694250830&lang=zh_CN#rd

 

 

;