今天为了解决“机器人再封装”的问题,遇到了以下需求:

商城中下载的机器人(记为ProjectA)通过设计器发布的路径默认为:D:\Program Files\IS-RPA10\Python\Lib\ubpalib\i3c9bc25df8624c38874dfd40deef1f4d

D:\Program Files\IS-RPA10 为设计器的安装路径

i3c9bc25df8624c38874dfd40deef1f4d是ProjectA发布后系统自动生成的文件夹名称

我试图在新开发的工程包ProjectB中调用事先下载的 ProjectA。

当然本地调用的话,使用机器人变量进行操作就能实现该需求。

为了使用户在未下载 ProjectA 的情况下,下载 ProjectB 也能正常运行,我就做了以下尝试:将 i3c9bc25df8624c38874dfd40deef1f4d 文件夹拷贝到工程 ProjectB 的执行路径下。(这段有点绕口,不知道有没有给大家描述清楚)

代码如下

import os#调出os库
#文件的复制
def mycopy(file1,file2):#定义一个mycopy函数用于复制文件
f1=open(file1,"rb") #以读取模式打开file1
f2=open(file2,"wb") #以清空写模式打开file2
content = f1.readline() #将第一行数据赋给content
while len(content)>0: #如果读取到的数据长度不为0则循环执行
f2.write(content) #在file2里写下content
content=f1.readline() #再读一行赋给content
f1.close() #关闭file1
f2.close()
#自定义目录复制函数
def copydd(dir1,dir2):#定义复制文件夹函数coppydd
#获取被复制目录中的所有文件信息
dlist = os.listdir(dir1) #以列表模式赋给dlist
#创建新目录
os.mkdir(dir2) #创建新文件夹dir2
#遍历所有文件并执行文件复制
for f in dlist: #让f在dlist中遍历
#为遍历的文件添加目录路径
file1 = os.path.join(dir1,f) #将f遍历出的文件名给file1(dir1+f即路径+文件名)
file2 = os.path.join(dir2,f) #同样也给file2
#判断是否是文件
if os.path.isfile(file1): #判断是否为文件的方式为os库中的函数 os.path.isfile(文件名)
mycopy(file1,file2) #调用自定义的mycopy函数复制文件
if os.path.isdir(file1): #如果是文件夹的话 那就调用自身(自身就是复制文件夹嘛)e而处理的不是dir1,dir2,是file1,file2,因为此时文件夹同文件一起被f遍历,此处判断的就是f遍历出的是文件还是文件夹
coppydd(file1,file2) #调用自身 递归思想
# 旧路径
dir1 = (os.path.abspath(os.path.join(os.path.dirname(__file__)))+'\\i3b4516ba2d6442a68426b27688ab5427')
# 新路径
dir2 = r"D:\Program Files\IS-RPA10\Python\Lib\ubpalib"+"\\i3b4516ba2d6442a68426b27688ab5427"
#dir1文件夹复制到dir2文件夹 没有会自动创建
copydd(dir1,dir2)

按照以上代码,文件夹的移动就完成啦。

当然我的尝试并没有成功解决“机器人再封装”的问题 😕,机器人变量的默认值是系统给定不可更改的 😩

今天的分享,完 😕