Linux下批量修改文件名

Linux下批量修改文件名,第1张

Linux下修改文件有mv和rename。其中mv命令只能对单个文件重命名,这是mv命令和rename命令的在重命名方面的根本区别。

linux的rename命令有两个版本,一个是c语言版本的,一个是perl语言版本的,判断方法:

输入man rename 看到第一行是:

RENAME(1) Linux Programmer’s Manual RENAME(1)

这个就是C语言版本的

而如果出现:

RENAME(1) Perl Programmers Reference Guide RENAME(1) 则是Perl版本的了

C语言版本格式:rename 原字符串 新字符串 文件名

Perl语言版本格式:rename 's/原字符串/新字符串/' 文件名

rename支持正则表达式

例子:

字母的替换 rename "s/AA/aa/" * // 把文件名中的AA替换成aa

修改文件的后缀 rename "s//.html//.php/" * // 把.html 后缀的改成 .php后缀

批量添加文件后缀 rename "s/$//.txt/" * // 把所有的文件名都以txt结尾

批量删除文件名 rename "s//.txt//" * // 把所有以.txt结尾的文件名的.txt删掉

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

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7552680.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-07
下一篇2023-04-07

发表评论

登录后才能评论

评论列表(0条)

    保存