最近接到一个产品需求是给指定的 sftp 服务器的指定目录定时推送文件数据。
因为项目组已有现成的组件可以轻松实现 sftp 服务器文件的快速上传,本来是一件很容易的事情,但是问题出现在这个指定的 sftp 服务器所指定的密码带有系统关键字和一些特殊字符,导致现在的组件在解析过程中会失败。
因此重新开发了下面的这套脚本来满足这个特殊的需求。
Python代码
sftp配置文件代码
(1). yaml 模块
导入 yaml 模块前可以使用以下命令进行模块的安装
yaml 模块在这里的作用是读取 sftp 配置文件代码,将指定key: test_file_upload 下的 key:value 的值转换为字典。
例如:load_config_from_param_conf 函数中的返回值就是使用 yaml 读取到 sftp 配置文件代码后,返回 key: test_file_upload 下配置选项值。
格式如下:
最后将返回值传给 upload 函数作为参数。
(2). OptionParser 模块
按照 yaml 模块的安装方法,先安装 optparse 模块后,然后在文件中从optparse 中导入 OptionParser 模块
在这里我使用了 OptionParser 这个类实例化了一个对象:opt_parser,通过对象来调用 add_option 方法添加了2个参数,分别是:node, local_file
1). 形参:--node,实参:node
所代表的业务含义是:指定要上传的 sftp 的节点,具体参数值对应 sftp配置文件代码中的 test_file_upload
2). 形参:--local_file,实参:local_file
所代表的业务含义是:指定本地需要被上传到 sftp 服务器的具体文件路径
3). 调用命令
4). add_option()方法
参数:action的枚举
store: 参数列表中带有--node, 那么就会将下一个元素即:test_file_upload 作为其 dest 实参 node 的值如果没有--node,那么对应的node的值就为 None
store_true: 参数列表中有--local_file, 那么其 dest 实参 local_file 的值就为 True否者就为 default 定义的默认值,这里没有给定 default 的默认值
store_false: 参数列表中有--local_file, 那么其 dest 实参 local_file 的值就为 False否者就为 default 定义的默认值,这里没有给定 default 的默认值
参数:type
type是指定传入参数的类型,这里的参数类型为 string 类型。
参数:dest
dest是参数传入后由哪个变量来存储的,后面代码对该参数的引用也是使用这里定义的变量名来引用的。
参数:default
default 是与 action 的值结合使用的。
参数:help
help相当于帮助说明文档,用于描述这个参数的含义。
自动化OFFICE办公软件是指在OFFICE的基础上建立一些软件,这些软件能自动执行一些常用的 *** 作集。比如自动排版、自动根据数据生成报表(基于OFFICE格式文件)等说起OA(Office Automation,办公自动化),几乎是人们都熟识和耳闻的一个IT名词。然而什么是OA?却是众说纷纭、莫衷一是。这主要是因为随着计算机技术、通信技术和网络技术的突飞猛进,关于oa
软件的描述也在不断充实,但至今还没有人对OA下过最权威、最科学、最全面、最准确的定义。其实OA的概念是动态的,进化论不管是其外延还是内涵,已与十几年前的OA发生了很大的变化。 总体上讲,它是指一切可满足于企事业单位的、综合型的、能够提高单位内部信息交流、共享、流转处理的和实现办公自动化和提高工作效率的各种信息化设备和应用软件;它不是孤立存在的,而是与企事业单位其它各类管理系统(如电子政务系统、电子商务系统、CRM系统、ERP系统、财务系统)密切相关、有机整合。一个独立存在的OA办公自动化系统生命力及作用是薄弱的。——这也是目前最全面、最被认可的oa
软件的概念。办公自动化的发展经历了四个阶段:从PC机加上个人办公软件实现的文字处理是第一个阶段,这个阶段大概在80年代到90年代初,大家主要是实现文字处理,就是单机的办公自动化;第二个阶段是局域网的出现,局域网和关系数据库实现了文件共享、信息共享,这个应该在90年代的初期;第三个阶段,这个阶段的特点是以群件技术为基础、以协同工作和知识管理为目标的办公自动化。第四个阶段,即协同办公门户,这个阶段的特点是OA系统作为整个组织内部信息化的入口,相对于外部门户(互联网网站)。与组织内各个业务系统进行集成,数据集中展现
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)