c语言目录操作总结
===================================================
char *getcwd( char *buffer, int maxlen ); (获取当前目录)
// 功 能 : 获得当前工作目录.
// 头文件 : #include <direct.h>
// 返回值 : 成功返回指向buffer的pointer
// 失败返回NULL,且设置errno为以下三个值之一:
// ENODEV 无该设备
// ENOMEM 内存不够
// ERANGE 结果超出范围
// 注 意 : 当第一个参数为 NULL 时, 第二个参数 maxlen 长度设置无效,且函数
// 使用 malloc 分配足够内存, 需要将函数返回值传递给 free() 函数来
// 释放内存. 当第一个参数不为 NULL 时,maxlen 指定长度不够函数返回
// 错误,设置errno为ERANGE
====================================================
int chdir( const char *dirname ); (改变当前目录)
// 功 能 : 更改当前工作目录.
// 头文件 : #include <direct.h>
// 返回值 : 成功返回0
// 失败返回-1,且设置errno如下:
// ENOENT 该路径不存在
====================================================
long _findfirst( char *filespec, struct _finddata_t *fileinfo );
// 功 能 : 提供与filespec指定入口泛式匹配的第一个文件.通常后继用_findnext函
// 数后续使用来完成某泛式下的文件遍历.
// 头文件 : #include <io.h>
// 参 数 : filespec - 指定的目录名或文件名,如"D:\\*.txt" 或 “*.*”
// fileinfo - 文件信息buffer
// 返回值 : 成功返回唯一的搜索句柄
// 出错返回-1,且设置errno为如下值:
// ENOENT 该泛式无法匹配
// EINVAL 无效文件名
// 注 意 : _finddata_t 说明 struct _finddata_t
{
unsigned attrib;
time_t time_create;
time_t time_access;
time_t time_write;
_fsize_t size;
char name[_MAX_FNAME];
};
// 其中 :
// unsigned atrrib : 文件属性的存储位置。它存储一个unsigned单元,用于表示文件的
// 属性。文件属性是用位表示的,主要有以下一些:_A_ARCH(存档)、
// _A_HIDDEN(隐藏)、_A_NORMAL(正常)、_A_RDONLY(只读)、
// _A_SUBDIR(文件夹)、_A_SYSTEM(系统)。这些都是在<io.h>中
// 定义的宏,可以直接使用,而本身的意义其实是一个无符号整型
// (只不过这个整型应该是2的几次幂,从而保证只有一位为1,而其他
// 位为0)。既然是位表示,那么当一个文件有多个属性时,它往往是
// 通过位或的方式,来得到几个属性的综合。例如只读+隐藏+系统属性,
// 应该为:_A_HIDDEN | _A_RDONLY |_A_SYSTEM 。
// time_t time_create:这里的time_t是一个变量类型,用来存储文件创建时间。
// time_t time_access: 文件最后一次被访问的时间。
// time_t time_write : 文件最后一次被修改的时间。
// _fsize_t size : 文件的大小。这里的_fsize_t应该可以相当于unsigned整型,表示
// 文件的字节数。
// char name[_MAX_FNAME]:文件的文件名。这里的_MAX_FNAME是一个常量宏,它在<stdlib.h>头
// 文件中被定义,表示的是文件名的最大长度。 ====================================================
int _findnext( long handle, struct _finddata_t *fileinfo );
// 功 能 : 按照前面_findfirst中的泛式规则,查找下一个符合该泛式的文件,并以此为依据
// 修改fileinfo中的值
// 头文件 : #include <io.h>
// 参 数 : long handle - 搜索句柄(通常由紧靠其前的_findfirst()返回)
// fileinfo - 文件信息buffer
// 返回值 : 成功返回0
// 出错返回-1,且设置errno为如下值:
// ENOENT 没有更多的符合该泛式的文件 ====================================================
int _findclose( long handle );
// 功 能 : 关闭搜寻句柄并释放相应资源
// 头文件 : #include <io.h>
// 参 数 : long handle - 搜索句柄(通常由紧靠其前的_findfirst()返回)
// 返回值 : 成功返回0
// 出错返回-1,且设置errno为如下值:
// ENOENT 没有更多的符合该泛式的文件 ====================================================
int mkdir( const char *dirname );
// 功 能 : 创建一个新目录,目录名为dirname.
// 头文件 : #include <direct.h>
// 返回值 : 成功返回0
// 失败返回-1,且设置errno为以下三个值之一:
// EACCESS 权限不允许
// EEXIST 该目录已存在
// ENOENT 无该文件或目录 ====================================================
int rmdir( const char *dirname );
// 功 能 : 删除名为dirname的目录.
// 头文件 : #include <direct.h>
// 返回值 : 成功返回0
// 失败返回-1,且设置errno为以下三个值之一:
// EACCESS : 权限不允许
// ENOTEMPTY : dirname不是文件夹;或者该文件夹不空;或
// 者dirname为当前工作文件夹;或者dirname
// 为当根文件夹;
// ENOENT : 无该文件或目录 ====================================================
int access( const char *path, int mode );
// 功 能 : 测定文件/目录存取权限.
// 头文件 : #include <io.h>
// 参 数 : path - 文件或者目录
// mode - 权限设定,其值如下:
// 00 Existence only
// 02 Write permission
// 04 Read permission
// 06 Read and write permission ====================================================
int chdrive( int drive );
// 功 能 : 更改当前工作驱动器.
// 头文件 : #include <direct.h>
// 返回值 : 成功返回0
// 失败返回-1
// 注 释 : 参数说明
// drive =1 : A盘
// drive =2 : B盘
// drive =3 : C盘 ... ====================================================
char* getdcwd( int drive, char *buffer, int maxlen );
// 功 能 : 获得指定驱动器的当前工作路径.
// 头文件 : #include <direct.h>
// 返回值 : 成功返回指向buffer的pointer
// 失败返回NULL,且设置errno为以下三个值之一:
// ENODEV 无该设备
// ENOMEM 内存不够
// ERANGE 结果超出范围
// 注 意 : 当第一个参数为 NULL 时,该函数设置errno为ERANGE ====================================================
int getdisk() 取当前正在使用的驱动器,返回一个整数(=A,=B,=C等) ====================================================
char *mktemp(char *template) 构造一个当前目录上没有的文件名并存于template中 ====================================================
int fnsplit(char *path,char *drive,char *dir,char *name,char *ext)
此函数将文件名path分解成盘符drive(C:、A:等),路径dir(\TC、\BC\LIB等),文件名name(TC、WPS等),
扩展名ext(.EXE、.COM等),并分别存入相应的变量中. ====================================================
void fumerge(char *path,char *drive,char *dir,char *name,char *ext)
此函数通过盘符drive(C:、A:等),路径dir(\TC、\BC\LIB等),文件名name(TC、WPS等),扩展名ext(.EXE、.COM等)
组成一个文件名,存在path中. ====================================================
范例:
#include <stdio.h>
#include <string.h>
#include <direct.h>
#include <malloc.h>
#include <io.h> /*
int SearchPath(char *pszPath)
{
char szBuf[100];
memset(szBuf, 0, sizeof(szBuf)); if (NULL != getcwd(szBuf, sizeof(szBuf))) printf("%s\n", szBuf);
} int rv = 0;
rv = chdir("C:\\Users\\SKS\\Desktop\\0114文件操作");
if (0 != rv)
{
printf("func chdir() error\n");
rv = -1;
return rv;
} char *pszNewPath = getcwd(NULL, 0);
printf("%s\n", pszNewPath);
free(pszNewPath); struct _finddata_t data;
long handle = _findfirst("*.*", &data);
if (handle < 0)
{
return rv;
}
int nRet = handle < 0 ? -1 : 1;
while (nRet >= 0)
{
if (data.attrib == _A_SUBDIR )
{//
printf(" [%s]*\n", data.name ); }
else
{
printf(" [%s]\n", data.name );
}
nRet = _findnext( handle, &data );
} _findclose( handle ); // 关闭当前句柄
return rv;
}
*/
long nLen = ;
int GetFileLength(char *pszPath)
{
FILE *pRead = fopen(pszPath, "r");
if (NULL == pRead)
{
return -;
}
char szBuf[];
while (!feof(pRead))
{
fgets(szBuf, sizeof(szBuf), pRead);
nLen++;
} fclose(pRead); } int SearchPath(char *pszPath)
{
int rv = ;
rv = chdir(pszPath);
if ( != rv)
{
printf("func chdir() error\n");
rv = -;
return rv;
} struct _finddata_t data;
long handle;
if (-1L == (handle = _findfirst("*.*", &data))) //成功返回唯一的搜索句柄, 出错返回-1
{
return rv;
}
do
{
if (data.attrib == _A_SUBDIR )
{//目录类型
char szBuf[] = {};
if (strcmp(data.name, ".") != && strcmp(data.name, "..") != )
{
sprintf(szBuf, "%s\\%s", pszPath, data.name);
SearchPath(szBuf);
}
}
else
{//单个文件
int nLen = strlen(data.name);
if (data.name[nLen - ] == 'p' && data.name[nLen - ] == 'p' &&
data.name[nLen - ] == 'c' &&data.name[nLen - ] == '.' )
{//过滤出所有cpp的文件
printf(" [%s]\n", data.name );
char szBuf[] = {};
sprintf(szBuf, "%s\\%s", pszPath, data.name);
GetFileLength(szBuf);
}
}
} while(_findnext( handle, &data ) == ); //成功返回0 , 出错返回-1 _findclose( handle ); // 关闭当前句柄 return rv;
} int main()
{
char *pszPath = "C:\\Users\\SKS\\Desktop\\谷歌大赛";
SearchPath(pszPath);
printf("%ld\n", nLen);
return ;
}
c语言目录操作总结的更多相关文章
- Python::OS 模块 -- 文件和目录操作
os模块的简介参看 Python::OS 模块 -- 简介 os模块的进程管理 Python::OS 模块 -- 进程管理 os模块的进程参数 Python::OS 模块 -- 进程参数 os模块中包 ...
- Python中的文件和目录操作实现
Python中的文件和目录操作实现 对于文件和目录的处理,虽然可以通过操作系统命令来完成,但是Python语言为了便于开发人员以编程的方式处理相关工作,提供了许多处理文件和目录的内置函数.重要的是,这 ...
- C语言文件操作 FILE结构体
内存中的数据都是暂时的,当程序结束时,它们都将丢失.为了永久性的保存大量的数据,C语言提供了对文件的操作. 1.文件和流 C将每个文件简单地作为顺序字节流(如下图).每个文件用文件结束符结束,或者在特 ...
- Linux 文件/目录操作详解
目录 Linux 文件/目录操作详解 初识Linux 一.文件/目录显示命令 ls 二.目录创建命令 mkdir 三.目录转移命令 cd 四.当前目录显示命令 pwd 五.文件处理命令 rmdir 六 ...
- Python技法:实用运维脚本编写(进程/文件/目录操作)
Python在很大程度上可以对shell脚本进行替代.笔者一般单行命令用shell,复杂点的多行操作就直接用Python了.这篇文章就归纳一下Python的一些实用脚本操作. 1. 执行外部程序或命令 ...
- 【C#公共帮助类】FTPClientHelper帮助类,实现文件上传,目录操作,下载等动作
关于本文档的说明 本文档使用Socket通信方式来实现ftp文件的上传下载等命令的执行 欢迎传播分享,必须保持原作者的信息,但禁止将该文档直接用于商业盈利. 本人自从几年前走上编程之路,一直致力于收集 ...
- liunx学习(一):linux下目录操作大全
Linux C函数之文件及目录函数(全):http://blog.sina.com.cn/s/blog_695e489c01013ldd.html linux目录操作发:http://www.cnbl ...
- go语言文件操作,这期资料比较详细( 欢迎加入go语言群: 218160862 )
go语言文件操作,这期资料比较详细 欢迎加入go语言群: go语言深圳群 golang深圳 218160862 点击加入 文件操作 func Open(name string) (file *File ...
- C语言字符串操作总结大全(超详细)
本篇文章是对C语言字符串操作进行了详细的总结分析,需要的朋友参考下 1)字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 strcat( ...
随机推荐
- LintCode-112.删除排序链表中的重复元素
删除排序链表中的重复元素 给定一个排序链表,删除所有重复的元素每个元素只留下一个. 样例 给出 1->1->2->null,返回 1->2->null 给出 1-> ...
- LintCode-212.空格替换
空格替换 设计一种方法,将一个字符串中的所有空格替换成 %20 .你可以假设该字符串有足够的空间来加入新的字符,且你得到的是"真实的"字符长度. 你的程序还需要返回被替换后的字符串 ...
- MVC4+EF5 edmx代码分析
本文分析Entity Framework(EF)从数据库自动生成的模型文件代码(扩展名为edmx). 一. 概述 本文使用的数据库结构尽量简单,只有2个表,一个用户表和一个分公司表(相当于部门表),一 ...
- 【Asp.Net Core】ASP.NET Core 2.0 + EF6 + Linux +MySql混搭
好消息!特好消息!同时使用ASP.NET Core 2.0和.NET Framework类库还能运行在linux上的方法来啦! 是的,你没有看错!ASP.NET Core 2.0,.NET Frame ...
- Lucene笔记一
Lucene就是一个全文检索的工具,建立索引用的,类似于新华字典的目录 这里使用的是lucene-4.4.0版本,入门代码所需jar包如下图所示(解压lucene-4.4.0后的目录): 入门代码: ...
- 《转》玩转图片Base64编码
引言 图片处理在前端工作中可谓占据了很重要的一壁江山.而图片的 base64 编码可能相对一些人而言比较陌生,本文不是从纯技术的角度去讨论图片的 base64 编码.标题略大,不过只是希望通过一些浅显 ...
- Socket网络编程实例1
Socket: 对所有上层协议(TCP/IP,UDP等)的底层封装. 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket. 建立网络通信连接至少要一对端口号(so ...
- 详解 ES6 Modules
详解 ES6 Modules 对于新人朋友来说,想要自己去搞定一个ES6开发环境并不是一件容易的事情,因为构建工具的学习本身又是一个非常大的方向,我们需要花费不少的时间才能掌握它. 好在慢慢的开始有大 ...
- [洛谷P2106]Sam数
题目大意:问长度为$n$的$Sam$数有几个,$Sam$数的定义为没有前导零,相邻两个数字之差绝对值小于等于$2$的数 题解:发现转移方程一定,可以矩阵快速幂. 卡点:没有特判$n=1$的情况 C++ ...
- Codeforces Round #469 (Div. 2) E. Data Center Maintenance
tarjan 题意: 有n个数据维护中心,每个在h小时中需要1个小时维护,有m个雇主,他们的中心分别为c1,c2,要求这两个数据中心不能同时维护. 现在要挑出一个数据中心的子集,把他们的维护时间都推后 ...