#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <dirent.h>
#include <string.h>
#include <iconv.h>
#include <errno.h>
/*int to_iconv(char *in,size_t in_bytes,char *out,size_t out_bytes,
const char *from,const char *to)*/
int to_iconv(char *in,char *out,size_t out_bytes,const char *from,const char *to)
{
iconv_t cd
size_t in_bytes=strlen(in)
//size_t out_bytes
if((cd=iconv_open(to,from)) == (iconv_t)-1)
{
perror("iconv_open")
return -1
}
if(iconv(cd,&in,&in_bytes,&out,&out_bytes) == -1)
{
perror("iconv")
return -1
}
iconv_close(cd)
return 0
}
void read_and_iconv(char *path,const char *from,const char *to)
{
DIR *dirp
struct dirent *dir
struct stat buf
char temp[512]//用于保存转换后的文件名称
if((dirp=opendir(path)) == NULL) //读取文件夹
{
perror("opendir")
return
}
chdir(path)//进入到该文件夹内部
while(dir=readdir(dirp)) //读取该文件夹下所有文件
{
if((strcmp(dir->d_name,".") == 0) || (strcmp(dir->d_name,"..") == 0))
//过滤掉.以及..文件夹,不然会死循环的
continue
bzero(temp,sizeof(temp))
to_iconv(dir->d_name,temp,sizeof(temp),from,to)//进行编码转换
rename(dir->d_name,temp)//进行重命名
printf("rename %s to %s\n",dir->d_name,temp)
stat(temp,&buf)
if(S_ISDIR(buf.st_mode)) //判断当前读取的文件是否为文件夹
{
read_and_iconv(temp,from,to)//如果是则递归处理
chdir("..")//处理完成后一定要记得返回上一层目录哦,不然其它文件就无法处理了
}
}
closedir(dirp)
}
int main(int argc,char **argv)
{
read_and_iconv(argv[1],argv[2],argv[3])
/*第一个参数是要转换的文件夹所在的文件夹名称
*第二个参数是文件名称所使用的编码(这里为GBK)
*第三个参数是要转换成何种编码(这里为UTF-8)
*/
return 0
}
rename函数功能是给一个文件重命名,用该函数可以实现文件移动功能,把一个文件的完整路径的盘符改一下就实现了这个文件的移动。具体参见下面的程序示例说明。头文件:在Visual C++6.0中用stdio.h或者io.h
用 法: int rename(char *oldname, char *newname)
程序例:
#include
int main(void)
{
char oldname[80], newname[80]
/* prompt for file to rename and new name */
printf("File to rename: ")
gets(oldname)
printf("New name: ")
gets(newname)
/* Rename the file */
if (rename(oldname, newname) == 0)
printf("Renamed %s to %s.\n", oldname, newname)
else
perror("rename")
return 0
}
执行过程:
File to rename: D:\\in.dat
New name: G:\\in.dat
Renamed D:\\in.dat to G:\\in.dat.
这样就实现了in.dat从D盘移动到G盘。
在unix或linux系统中:
#include
int rename(const char *oldname, const char *newname)
函数说明
(1) 如果oldname为一个文件而不是目录,那么为该文件更名。在这种情况下,如果newname作为一个目录已存在,则它不能重命名一个目录。如果newname已存在,而且不是一个目录,则先将其删除然后将oldname更名为newname。对oldname所在目录以及newname所在的目录,调用进程必须具有写许可权,因为将更改这两个目录。
(2) 如若oldname为一个目录,那么为该目录更名。如果newname已存在,则它必须是一个目录,而且该目录应当是空目录(空目录指的是该目录中只有. 和.. 项)。如果newname存在(而且是一个空目录),则先将其删除,然后将oldname更名为newname。另外,当为一个目录更名时,newname不能包含oldname作为其路径前缀。例如,不能将/usr更名为/usr/foo/testdir,因为老名字( /usr/foo)是新名字的路径前缀,因而不能将其删除。
(3) 作为一个特例,如果oldname和newname引用同一文件,则函数不做任何更改而成功返回。
返回值 执行成功则返回0,失败返回-1,错误原因存于errno
范例
#include
int main(int argc,char **argv)
{
if(argc <3)
{
printf("Usage: %s old_name new_name\n",argv[0])
return -1
}
printf("%s =>%s\n", argv[1], argv[2])
if(rename(argv[1], argv[2]) <0 )
printf("error!\n")
else
printf("ok!\n")
return 0
}
#include <stdio.h>int main(void)
{
char oldname[80], newname[80]
/* prompt for file to rename and new name */
printf( "File to rename: ")
gets(oldname)
printf( "New name: ")
gets(newname)
/* Rename the file */
if (rename(oldname, newname) == 0)
printf( "Renamed %s to %s.\n ", oldname, newname)
else
perror( "rename ")
return 0
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)