python之工作举例:通过复制NC文件来造数据

 

 

  1 # 通过对NC文件复制来造数据
  2 import os, shutil
  3 
  4 # 遍历的根目录
  5 root_dir = "D:\\test_data\\DISASTER\\"
  6 # 获取NC文件的时间
  7 time_source = '20161228080000'
  8 # 生成NC文件的时间
  9 time_new = '20181228080000'
 10 
 11 
 12 def get_dir_path(dir_name, time_str):
 13     '''
 14     组装目录结构
 15     :param dir_name:文件名
 16     :param time_str:时间字符串,如“20161228080000”
 17     :return:目录路径
 18     '''
 19     dir_path = root_dir + dir_name + '\\' + time_str[0:4] + '\\' + time_str[0:6] + '\\' + time_str[0:8] + '\\'
 20     return dir_path
 21 
 22 
 23 def get_new_file_name(source_file_name, time_source, time_new):
 24     '''
 25     根据源文件和时间生成新的文件名称
 26     :param source_file_name:源文件名
 27     :param time_source:源文件时间
 28     :param time_new:新文件时间
 29     :return: 新的文件名
 30     '''
 31     list_pices = source_file_name.split('_')
 32     # print(list_pices)
 33     new_file_name = list_pices[0]
 34     for s in list_pices[1:]:
 35         if s == time_source:
 36             # print(s)
 37             new_file_name += '_' + time_new
 38         else:
 39             new_file_name += '_' + str(s)
 40     print("源文件名:", source_file_name)
 41     print("新文件名:", new_file_name)
 42     return new_file_name
 43 
 44 
 45 def copy_file(source_file, new_file_name, new_dir):
 46     '''
 47     拷贝文件,并检查文件是否存在
 48     :param source_file: 原文件完整路径包含目录路径和文件名
 49     :param new_file_name: 新文件名称
 50     :param new_dir: 新文件目录路径
 51     :return: 无
 52     '''
 53     if os.path.exists(new_dir):
 54         print("目标目录已存在:", new_dir)
 55     else:
 56         print('目标目录新建成功!', new_dir)
 57         os.makedirs(new_dir)  # 创建多级目录
 58     # 复制文件
 59     new_whole_file = new_dir + new_file_name
 60     shutil.copy(source_file, new_whole_file)
 61     if os.path.exists(new_whole_file):
 62         print("文件复制成功!", new_whole_file)
 63     else:
 64         print("文件复制失败!", new_whole_file)
 65 
 66 
 67 def find_and_copy_nc(root_dir, time_source, time_new):
 68     '''
 69     遍历获取需要拷贝的原NC文件
 70     拷贝到新目录下
 71     :param root_dir: 文件根目录
 72     :param time_source: 源文件时间
 73     :param time_new: 目标文件时间
 74     '''
 75     # 遍历根目录,获取天气现象文件夹列表
 76     dir_list = os.listdir(root_dir)
 77     for dir in dir_list:
 78         '''遍历各天气现象要素目录'''
 79         print('#' * 25)
 80         print(dir)
 81         # 组装源NC文件父目录路径
 82         parent_dir = get_dir_path(dir, time_source)
 83         print("源目录路径:", parent_dir)
 84         new_dir = get_dir_path(dir, time_new)
 85         print("目标目录路径:", new_dir)
 86         try:
 87             '''
 88             获取NC文件目录下的文件列表
 89             目录不存在就退出循环
 90             '''
 91             file_list = os.listdir(parent_dir)
 92         except:
 93             print("源目录不存在:", parent_dir)
 94             continue
 95 
 96         for source_file_name in file_list:
 97             '''遍历NC文件列表'''
 98             if source_file_name.count(time_source) > 0:
 99                 print('-' * 20)
100                 # print("源文件名:", source_file_name)
101                 new_file_name = get_new_file_name(source_file_name, time_source, time_new)
102                 # print("目标文件名:", new_file_name)
103                 copy_file(parent_dir + source_file_name, new_file_name, new_dir)
104 
105 
106 find_and_copy_nc(root_dir, time_source, time_new)

 

转载于:https://www.cnblogs.com/gongxr/p/7355401.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/454954.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python 3.5.2 TypeError: a bytes-like object is required, not 'str’问题解决方案

运行环境Mac Python 3.5.2 Q: http_response """\ HTTP/1.1 200 OK Hello, World! """ client_connection.sendall(http_response) TypeError: a bytes-like object is required, not str 类型错误,需要的是一个byte类型&#xff0…

mysql 集群架构_mysql企业常用集群架构

转自 https://blog.csdn.net/kingice1014/article/details/760200611、mysql企业常用集群架构在中小型互联网的企业中。mysql的集群一般就是上图的架构。WEB节点读取数据库的时候读取dbproxy服务器。dbproxy服务器通过对SQL语句的判断来进行数据库的读写分离。读请求负载到从库…

h.264视频文件封装

所谓封装格式就是将已经编码压缩好的视频轨和音频轨按照一定的格式放到一个文件中,也就是说仅仅是一个外壳,或者大家把它当成一个放视频轨和音频轨的文件夹也可以。说得通俗点,视频轨相当于饭,而音频轨相当于菜,封装格…

python cookbook 笔记三

分组: rows [{address: 5412 N CLARK, date: 07/01/2012},{address: 5148 N CLARK, date: 07/04/2012},{address: 5800 E 58TH, date: 07/02/2012},{address: 2122 N CLARK, date: 07/03/2012},{address: 5645 N RAVENSWOOD, date: 07/02/2012},{address: 1060 W A…

关于Vue2.0,Express实现的简单跨域

npm install express -g 通过npm全局安装express,之后可以通过 express --version 来查看express版本 express server 通过express server生成server项目文件 npm install 安装server的项目依赖 可以通过执行server下的bin\www文件可以开启服务 在www文件我们可以默…

mysql datetime类型按天查询_mysql 时间相关sql , 按天、月、季度、年等条件进行查询...

-- mysql查询本季度-- 今天select * from ticket_order_detail where to_days(use_time) to_days(now());-- 7天SELECT *FROM ticket_order_detail where DATE_SUB(CURDATE(), INTERVAL 7 DAY) < date( use_time)-- 近30天SELECT *FROM ticket_order_detail where DATE_SUB…

ffmpeg分析系列

hello&#xff0c;各位好&#xff0c;本人是一名嵌入式软件工程师&#xff0c;目前正使用ffmpeg开发一款嵌入式多媒体播放器&#xff0c;《ffmpeg分析》系列博文是本人在阅读ffmpeg源代码时所做的笔记&#xff0c;希望对各位有点帮助。分析过程结合下面的例程&#xff1a;http:…

Linux kernel的中断子系统之(二):IRQ Domain介绍

返回目录&#xff1a;《ARM-Linux中断系统》。 总结&#xff1a;一、二概述了软硬件不同角度的IRQ Number和HW Interrupt ID&#xff0c;这就需要他们之间架个桥梁。 三介绍了架设这种桥梁的几种方式&#xff1a;Linear、Radix Tree和no map。 四介绍了两种基础数据结构描述中断…

mysql返回yyyy mm dd_怎么把取出mysql数据库中的yyyy-MM-dd日期转成yyyy年MM月dd日格式...

您好&#xff0c;通过两个个步骤可以完成转换&#xff1a;第一步&#xff1a;日期处理可以在模板数据集中通过sql语句转换&#xff0c;转换方式方式如下&#xff1a;SELECT DATE_FORMAT(NOW(),%Y) YEAR输出结果&#xff1a;2018SELECT DATE_F…

关于JS的时间控制

关于JS的时间控制实现动态效果及实例操作 <script>BOM //Bowers Object Model 浏览器对象模型setTimeout() // 延迟执行一次setInterval() // 间隔执行var a 300;window.setTimeout(abc(a),3000); // 自定义函数赋值function abc(i){alert(i);}//setInterv…

感动一生的几句话

为什么80%的码农都做不了架构师&#xff1f;>>> 很多东西就掌握在我们手中&#xff1a; 比如快乐&#xff0c;你不快乐&#xff0c;谁会同情你的悲伤&#xff1b; 比如坚强&#xff0c;你不坚强&#xff0c;谁会怜悯你的懦弱&#xff1b; 比如努力&#xff0c;你不…

mysql5.6 memcached_MySQL 5.6 安装配置InnoDB memcached Plugin

准备工作, 安装libmemached包&#xff0c;提供一些memcat/cp/dump命令&#xff0c;方便测试。# yum install libmemcached.x86_64 -y1. Setup required tables.mysql> source MYSQL_HOME/share/innodb_memcached_config.sqlQuery OK, 1 row affected (0.00 sec)Database cha…

Java 监听器,国际化

1. 监听器 1.1 概述 监听器&#xff1a; 主要是用来监听特定对象的创建或销毁、属性的变化的&#xff01; 是一个实现特定接口的普通java类&#xff01; 对象&#xff1a; 自己创建自己用 (不用监听) 别人创建自己用 &#xff08;需要监听&#xff09; Servlet中哪些对象需要监…

patator mysql 字典_利用patator进行子域名爆破

前言:原来朋友写的一个子域名爆破工具挺好用,这前几天API接口关了.痛苦万分.自己也写了一个类似的但是不咋稳定.特地google找了下 找到一款patator.效果和速度还是不错的。knock的速度真心受不了啊patator是由Python写的 不用安装下载即可.下载地址&#xff1a;http://code.goo…

div 超出高度滚动条,超出宽度点点点

超出高度滚动条style"width:230px; height: 180px; overflow: auto;"超出宽度点点点style"width: 220px; overflow: hidden; white-space:nowrap; text-overflow:ellipsis;"转载于:https://www.cnblogs.com/thinkingthigh/p/7603703.html

mp4(H264容器)的详细文件格式分析

十六进制码流分析&#xff1a; ftyp Box 00 00 00 1C: size ,28,表示此BOX有28个字节&#xff0c;表示长度的四个字节也计算在内。以下同 66 74 79 70: type,表示BOX TYPE,此处为ftyp 6D 70 34 32: 可能是兼容的格式信息&#xff0c;/mp42 00 00 00…

hdu 5925 搜索

题意&#xff1a;一个图&#xff0c;n个障碍&#xff0c;求联通块 思路&#xff1a; 图很大&#xff0c;障碍物很少。把联通的障碍物块抠出来&#xff0c;然后暴力。 代码&#xff1a; #include<bits/stdc.h> using namespace std; #define MEM(a,b) memset(a,b,sizeof(a…

分析数据库CitusDB:提供弹性计算能力

本文讲的是分析数据库CitusDB&#xff1a;提供弹性计算能力,企业数据库市场很庞大&#xff0c;在这个领域既有Oracle这样行家&#xff0c;也有IBM(DB2)和微软(SQL Server)这样的跨界巨头。它们都与中小企业常用到的开源数据库MySQL一样&#xff0c;都属于传统关系型数据库。似乎…

mysql不能创建innodb类型表_MYSQL have_innodb DISABLED无法创建innodb类型的表

今天在一台MYSQL服务器上发现&#xff0c;明明用了engineinnodb创建的表&#xff0c;结果创建出来却成了myisam的表。再看show variables like %innodb%;have_innodb 成了DISABLED。经过一番试验&#xff0c;发现是我关闭数据库后&#xff0c;直接删除ibdata1文件造成的。删除该…

[bzoj1059]矩阵游戏

虽然是一道水难题&#xff0c;但是我这种蒟蒻还是要讲一讲的。 Description 小Q是一个非常聪明的孩子&#xff0c;除了国际象棋&#xff0c;他还很喜欢玩一个电脑益智游戏——矩阵游戏。矩阵游戏在一个N*N黑白方阵进行&#xff08;如同国际象棋一般&#xff0c;只是颜色是随意的…