文件操作API
文件操作API
最近遇到了一个困难。下的一部视频,有100来集,但每一集都放在单独的文件夹里。我现在想把他们移到一起,莫非要一个一个手工移?
正好以前看过一篇文章写的是遍历文件夹中指定文件,于是我可以利用它来解决我的问题。
遍历那个部分我就不讲了……涉及的东西太多(又是链表又是递归的)。先讲讲几个简单的API。
BOOL WINAPI CreateDirectory(
__in LPCTSTR lpPathName,
__in_opt LPSECURITY_ATTRIBUTES lpSecurityAttributes
);
作用:新建一个文件夹。我们要把所有视频移到一起,最好新建一个文件夹来保存。lpPathName 参数是文件夹的地址。比如在D:abc 下建立 def 文件夹,这个lpPathName 字符串就应该是_T("d:\abc\def").
_T是一个宏,表示字符串是TCHAR类型。关于字符串类型和字符编码这些问题我以后会说。API中的字符串一般用这个宏包着就好。
lpSecurityAttributes 参数是文件夹的安全属性,填NULL就可以。
这个函数返回值是BOOL类型。通过GetLastError 函数能得到出错的原因。( 关于出错原因那几个函数我做过一个PPT大家可以去看看 http://wenku.baidu.com/view/889e85270066f5335a81214b?fr=prin ) 如果文件夹已存在CreateDirectory函数就会出错,而且通过GetLastError 函数得到的错误代码为0x50.所以我们可以这样写一个判断句:
if( !CreateDirectory(lpPathName,NULL) )
{
DWORD err = GetLastError();
if( 0x50 == err )
{
MessageBox(NULL,_T("文件夹已存在"),_T("出错"),MB_OK);
}
}
通知我们的用户,因为什么原因出错了。
BOOL WINAPI CopyFile(
__in LPCTSTR lpExistingFileName,
__in LPCTSTR lpNewFileName,
__in BOOL bFailIfExists
);
作用:复制文件到指定文件夹。第一个参数是待复制文件的文件名,第二个参数是新文件名。注意,一般第一个参数我们不会填错,知道是填要复制的文件。但是第二个参数就容易弄错了,很容易就只写一个文件夹。比如要把文件移动到D:abc文件夹底下,第二个参数就填D:\abc. 这就会出错。
我一开始也是犯了这个错误。英文不好也没仔细看MSDN,结果程序写出来能运行却不能复制文件,后来调试以后发现是这个函数的问题。再仔细一查MSDN,才知道第二个参数应该填的是目标文件名。也就是说把x.txt移动到D:\abc文件夹底下,就应该填写_T("d:\abc\x.txt").
第三个参数是个BOOL型,填TRUE 代表:若目标文件已存在,不覆盖文件,函数返回错误。填FALSE代表:若目标文件已存在,覆盖文件。
函数返回值也是BOOL,可以通过GetLastError函数判断出错原因。如果你第三个参数填的TRUE,出错估计就是因为文件已存在。
两个我的程序里用到的API讲过了,再说几个简单的API:
BOOL WINAPI DeleteFile(
__in LPCTSTR lpFileName
);
作用:删除文件。
lpFileName :文件名。
BOOL WINAPI MoveFile(
__in LPCTSTR lpExistingFileName,
__in LPCTSTR lpNewFileName
);
作用:移动文件(剪切)。
两个参数和copy里面的前两个参数相似。这个函数我没用过,具体参阅MSDN。
其实还有一个功能强大的函数CreatFile 我没提到,因为它有点麻烦,涉及的参数比较多,以后可以单独讲讲。这里我已经完成我最开始说的那个程序的编写,有点简陋,作用是把你选择的目录中的所有wmv格式的文件移动到新建的一个目录里。
源代码发在附件里,工程用C-FREE建的。
- 绕过混合内容警告 - 在安全的页面加载不安全的内容
- 如何在Kerberos环境使用Flume采集Kafka数据并写入HDFS
- 熊市里生成几个BTC靓号,冷存储起来装死吧
- 傲游浏览器漏洞系列(上)- 任意文件写入,UXSS
- 如何使用Cloudera Manager在线为集群减容
- GitLab 任意文件读取漏洞 (CVE-2016-9086) 和任意用户 token 泄露漏洞
- 如何使用Hue通过数据文件创建Collections
- GNU tar 解压路径绕过漏洞(CVE-2016-6321) 分析
- Memcached 命令执行漏洞(CVE-2016-8704、CVE-2016-8705、CVE-2016-8706)简析
- 使用Hue创建Ssh的Oozie工作流时重定向输出日志报错分析
- Joomla未授权创建特权用户漏洞(CVE-2016-8869)分析
- 检测本地文件躲避安全分析
- 如何在Kerberos的Linux上安装及配置Impala的ODBC驱动
- 对抗静态分析——so文件的加密
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- flink教程-flink modules详解之使用hive函数
- 面试iOS 机会在自己手中
- Flink教程-将流式数据写入redis
- Flink教程-keyby 窗口数据倾斜的优化
- Flink源码分析之深度解读流式数据写入hive
- 浙大版《C语言程序设计(第3版)》题目集 习题10-1 判断满足条件的三位数
- 差分标记-HDU1556 Color the ball
- flink cep 案例之机架温度监控报警
- 详解flink 1.11中的新部署模式-Application模式
- 浙大版《C语言程序设计(第3版)》题目集 习题10-2 递归求阶乘和
- hadoop源码解析之RPC分析
- 存储过程和触发器
- hadoop源码学习之namenode启动
- 浙大版《C语言程序设计(第3版)》题目集 习题10-3 递归实现指数函数
- hadoop2.7.3源码解析之datanode注册和心跳机制