本方法原理是使用python(以下简称py)调用arcmap的gp,在上再用bat调用py的方式实现。优点是能应用于所有数据库类型(包括pg,oracle等)的sde库

环境:arcmap 10.4,pg版sde

本文以备份以下sde要素类,备份到本地D:\test1文件夹下面的gdb,备份时间间隔是每天一次

备份脚本是py语言,以下提供模板:

模板开始————————————————————————————

#coding:utf-8

# Import arcpy module

import arcpy

import datetime

# 备份本地文件gdb的文件夹路径

bak_gdb_path = "D:\\test1"

# 备份本地文件gdb的文件名(不要带.gdb)

bak_gdb_name="bak_xxx"

# 获取当天日期并按指定格式输出(本例每天备份所有精确到天,有需要按其他格式输出当前时间可以自行搜索py的日期时间输出方式)

today=datetime.date.today()

formatted_today=today.strftime('%Y%m%d')

# 最终的gdb文件名

bak_gdb_name_final=bak_gdb_name+"_"+formatted_today

# Process: 创建文件地理数据库

arcpy.CreateFileGDB_management(bak_gdb_path, bak_gdb_name_final, "CURRENT")

# 复制要素类(就是把sde的要素类复制到gdb,用这种方法实现备份),每复制一个要素类一行,要复制多个要素类,可以通过excel或者文本编辑器替换等当时批量按格式修改

# 参数1:sde的要素类路径,路径格式可以在arcmap使用导出导入等功能看

# 参数2:复制到gdb的路径,一般不用改

arcpy.FeatureClassToGeodatabase_conversion("数据库连接\\连接到sde_demo.sde\\sde_demo.sde.data\sde_demo.sde.SDE_DEMO_POLYGON", bak_gdb_path+"\\"+bak_gdb_name_final+".gdb")

模板结束————————————————————————————

在任意目录,新建一个py文件(本例文件名是test21.py),把模板内容复制进去,然后开始按实际修改,以下说明要改的

输出的本地文件位置

一般不用改

主要改参数1,有个问题是如何确定要导的sde要素类的“路径”?以及在需要导出多个要素类时如何快速生成?随便找个要打开要素类的gp,加载要素类后都会变成要素类的路径,批量执行gp还能获取到多个(换行版的),并且结合excel,记事本的文本替换等批量处理字符的处理方式

到此py文件编辑完毕,然后是手动调用测试和自动运行

调用py文件用到arcmap自带的python(arcmap安装时自带py,而且这里也必须用这个自带的,而不能自己装原版的py)

PS:arcmap自带py有个标志是安装目录下有个ArcGIS10.4(名称根据ArcGIS版本而不同)文件夹

cmd到py安装目录的这一个文件夹

cmd执行命令:python D:\test1\test21.py,其中后面的文件路径要按实际改

执行成功的样子

然后看看备份的gdb是否生成,数据是否复制正确

到此说明py脚本是正常的,然后开始配置定时执行

首先在备份脚本的py文件的文件夹下新建bat文件,本例名为test21.bat

内容如下:

前面一段是arcgis自带py的python.exe的位置,后面就是备份脚本的py文件的位置

"C:\Python27\ArcGIS10.4\python" D:\arcpy_test\test1.py

然后开始新建定时任务,定时执行使用windows的定时任务(也可以用jenkins的定时执行),这个大家应该比较熟悉,在mysql自动备份也有用到,下面也只说明关键位置

自动执行的内容就是上面新建的bat文件

到此自动任务配置完毕,注意自动任务执行有可能执行失败或者出现其他问题(手动执行成功不代表自动执行就一定成功),后续要观察一两次真正成功后才算真的成功

sde自动备份到文件gdb的更多相关文章

  1. oracle11g 新特性 - rman自动备份控制文件延迟

    OS: Oracle Linux Server release 5.7 DB: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 -6 ...

  2. LINUX 自动备份脚本文件

    首先我在/root/backup 目录下建立一个文件夹, #mkdir /root/backup/mysqlbackup 以后在每天五点钟,就会有一个文件保存在这里. 接着新建文件 #vim /roo ...

  3. 去掉EditPlus自动备份bak文件

    用EditPlus编辑文件是总是自动生成一个.bak文件. 其实想去掉EditPlus的自动备份也简单,方法如下: 打开菜单栏上的:工具->参数设置->文件 去掉“保存时创建备份文件”前的 ...

  4. CentOS中使用Shell脚本实现每天自动备份网站文件和数据库并上传到FTP中(转)

    http://www.jb51.net/article/58843.htm 一.安装Email发送程序 复制代码 代码如下: yum install sendmail mutt 二.安装FTP客户端程 ...

  5. RMAN兼容性、控制文件自动备份、保存时间、备份策略、备份脚本(二)

    RMAN 程序的兼容性 RMAN 环境由以下5部分组成:(1) RMAN executable(2) Recovery catalog database(3) Recovery catalog sch ...

  6. 关于 RMAN 控制文件自动备份路径中指定的 %F 说明

    默认情况下,RMAN备份的属性配置一共 14 行( show all; )来自博客园AskScuti CONFIGURE CONTROLFILE AUTOBACKUP FORMAT FOR DEVIC ...

  7. 【RMAN】Oracle中如何备份控制文件?备份控制文件的方式有哪几种?

    真题1. 如何备份控制文件?备份控制文件的方式有哪几种? 答案:备份控制文件的方式有多种. ① 备份控制文件可以在线进行: SQL> ALTER DATABASE BACKUP CONTROLF ...

  8. 170208、用Navicat自动备份mysql数据库

    数据库备份很重要,很多服务器经常遭到黑客的恶意攻击,造成数据丢失,如果没有及时备份的话,后果不堪设想. 一:备份的目的: 做灾难恢复:对损坏的数据进行恢复和还原 需求改变:因需求改变而需要把数据还原到 ...

  9. 用Navicat自动备份mysql数据库

    以下文章转载自https://blog.csdn.net/u013628152/article/details/54909885,放在自己的博客园以供后面方便查询 —————————————————— ...

随机推荐

  1. js中或者vue中 Object.assign()用法详解

    Object.assign()是浅拷贝. 合并对象 var o1 = { a: 1 }; var o2 = { b: 2 }; var o3 = { c: 3 }; var obj = Object. ...

  2. vue+elementUI 做的递归组件

    废话少说,直接上最新鲜的干货 当然,你得提前安装好bootstrap,router,element-ui,vue-axios 1.上递归组件,此处参考了某位大神的代码,具体不知道是谁,因为到处都有人用 ...

  3. pycharm2017版本永久激活

    亲测有效,为了以后方便查看,就复制粘贴了一下 声明:转自https://blog.csdn.net/qq_34173491/article/details/81157519 目前比较好用的Python ...

  4. prefetches

    用于设置预请求的所有url的列表,该部分URL,会在进入小程序后自动发起请求(优于开发者代码加载).当开发者再次发起request请求时可以增加cache参数,如果配置的prefetch请求已返回,则 ...

  5. VS2015编译问题:模块对于 SAFESEH 映像是不安全的

    严重性 代码 说明 项目 文件 行 禁止显示状态 错误 LNK2026 模块对于 SAFESEH 映像是不安全的. zlibvc C:\MyDirectory\test2\zlib-\contrib\ ...

  6. ASCII 、UTF-8、Unicode编码

    1.各种编码的由来 1.1.计算机编码的由来 因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理.所以只能是用一些数字来表示文本,这就是编码的由来.最早的计算机在设计时采用8个比 ...

  7. Codeforces 916B Jamie and Binary Sequence ( 模拟 && 思维 )

    题意 : 给出一个数 n ,要求你用 k 个二的幂来组成这个数,要求输出这 k 个二的幂的指数,如果有多解情况则优先输出最大指数最小的那一个且要求按字典序输出,不存在则输出 No 分析 :  先来说一 ...

  8. [CSP-S模拟测试]:老司机的狂欢(LIS+LCA)

    题目背景 光阴荏苒.不过,两个人还在,两支车队还在,熟悉的道路.熟悉的风景,也都还在.只是,这一次,没有了你死我活的博弈,似乎和谐了许多.然而在机房是不允许游戏的,所以班长$XZY$对游戏界面进行了降 ...

  9. shell中的=~的简单用法

    其中 ~ 其实是对后面的正则表达式表示匹配的意思,如果匹配就输出1, 不匹配就输出0 [[ $test =~ ^[0-9]+ ]] && echo 1 || echo 0

  10. 谷歌 AXURE RP EXTENSION拓展问题

    我们打开某种文件页面是 会提示我们下载 AXURE RP EXTENSION 拓展. 其实我们可以直接用ie浏览器打开即可,不用下载