rename 批量修改文件名
1.rename的用法
- -v(verbose)打印被成功重命名的文件,即打印执行过程
- -n(no-act)只显示将被重命名的文件,而非实际进行重命名操作
- -f(force)覆盖已经存在的文件
- files需要被替换的文件(比如*.c、*.h),如果没给出文件名,将从标准输入读
|
将(1).jpg
(2).jpg
…..
改为:
test_001.jpg
test_002.jpg
……
|
1、去掉括号
rename -n 's/[()]//g' *.jpg
2、继续重命名为想要的格式
rename -n 's/^/test_00/' *.jpg
|
解释:
-n直接打印结果在终端中而非实际执行
s代表substitution,替换的意思
[()]代表匹配[]中的内容
//两个斜杠之间是空代表替换为空的内容,相当于删除
g代表全部匹配,不加g的话默认只会匹配一个括号
^-在文件名称开头加字符
test_00-将名称前面添加上test_00
|
|
规则化数字编号名
将1.jpg, 2.jpg ..... 100.jpg
改为:
001.jpg,002.jpg,...023.jpg,...100.jpg
|
1.把1.jpg ..... 9.jpg 变换为001.jpg .... 009.jpg
rename 's/^/00/' [0-9].jpg
2. 把10.jpg ..... 99.jpg 变换为010.jpg ..... 090.jpg
rename 's/^/0/' [0-9][0-9].jpg
|
|
|
去除文件名中空格
|
1.老方法
find . -type f -name "* *" -print |while read name; do mv "${name}" `echo "${name}"|sed "s/[ ]\+/_/g"`;done
2.rename方法
rename "s/[ ]+/_/g" *
|
● 其中[ ]+表示空格出现一次或多次,空格可以用[:space:]代替,该命令可替换为[[:space:]]+
● 在sed中需要将+转义,但在rename中不能转义,因为rename 采用的是标准perl正则语法
● 从命令中能够看到sed与rename的区别,rename处理的是该目录下所能匹配到的所有文件,它将所有文件名作为处理的对象,而命令sed 处理的是文件内容,所以只能通过echo "文件名"|sed "s/[ ]\+/_/g的方式才能处理文件名
|
|
批量修改文件前缀
场景:folder A中有a.rtv b.a.c.imu a.t.gps a.y.ew.imu等等,想要将这些文件的文件名统一为test,后缀保持不变
|
一般的思路:
1.遍历folder,依次获取文件
2.获取文件后缀${pre}
3.使用mv ${file} test.${pre}
该方法中没有文件都要获取后缀再执行mv命令,灰常复杂
rename方法:
rename 's/.*\./test./' *
|
.*\.中.*代表匹配多次单个字符,\.代表对点进行转义。
|
|
其他:
|
rename 's/^/hello/' * 统一在文件头部添加上hello
rename 's/.html$/.htm/' * 统一把.html扩展名修改为.htm
rename 's/$/.zip/' * 统一在尾部追加.zip后缀:
rename 's/.zip$//' * 统一去掉.zip后缀
|
2.Perl正则表达式
|
匹配:m//
|
(可以省略m,直接写成/regexp/)
|
|
替换:s///
|
s/PATTERN/REPLACEMENT/egimosx
e 将右侧作为表达式计算。
g 全匹配
i 不区分大小写的模式匹配
m 将字符串视为多行。
o 只编译一次模式,即使其中的变量发生变化。
s 将字符串视为单行。
x 使用扩展正则表达式
|
|
转化:tr///
|
转化有两种等价表达方式,如下:
tr/SEARCHLIST/REPLACEMENTLIST/cds
y/SEARCHLIST/REPLACEMENTLIST/cds
c 补充 SEARCHLIST.
d 删除找到但未替换的字符
s 压缩重复的替换字符
|
|
rename -n 'tr/Sam3/Stm/' FastSpiSam3C.nc
替换字符短,用最后一个字符m替换3
|
FastSpiSam3C.nc renamed as FtstSpiStmmC.nc
|
|
rename -n 'tr/Sam3/Stm32/' FastSpiSam3C.nc
替换字符长,多出字符被忽略
|
FastSpiSam3C.nc renamed as FtstSpiStm3C.nc
|
|
x? 匹配 0 次或一次 x 字符串
|
\d 匹配一个数字的字符,和 [0-9] 语法一样
|
|
x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次数
|
\d+ 匹配多个数字字符串,和 [0-9]+ 语法一样
|
|
x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次数
|
\D 非数字,其他同 \d
|
|
.* 匹配 0 次或一次的任何字符
|
\D+ 非数字,其他同 \d+
|
|
.+ 匹配 1 次或多次的任何字符
|
\w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样
|
|
{m} 匹配刚好是 m 个 的指定字符串
|
\w+ 和 [a-zA-Z0-9]+ 语法一样
|
|
{m,n}匹配在 m个 以上 n个 以下 的指定字符串
|
\W 非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样
|
|
{m,} 匹配 m个 以上 的指定字符串
|
\W+ 和 [^a-zA-Z0-9]+ 语法一样
|
|
[] 匹配符合 [] 内的字符
|
\s 空格,和 [\n\t\r\f] 语法一样
|
|
[^] 匹配不符合 [] 内的字符
|
\s+ 和 [\n\t\r\f]+ 一样
|
|
[0-9]匹配所有数字字符
|
\S 非空格,和 [^\n\t\r\f] 语法一样
|
|
[a-z]匹配所有小写字母字符
|
\S+ 和 [^\n\t\r\f]+ 语法一样
|
|
[^0-9]匹配所有非数字字符
|
\b 匹配以英文字母,数字为边界的字符串
|
|
[^a-z]匹配所有非小写字母字符
|
\B 匹配不以英文字母,数值为边界的字符串
|
|
^ 匹配字符开头的字符
|
a|b|c 匹配符合a字符 或是b字符 或是c字符 的字符串
|
|
$ 匹配字符结尾的字符
|
abc 匹配含有 abc 的字符串
|
rename 批量修改文件名的更多相关文章
- rename 批量修改文件名简单用法
有的时候我们需要批量创建文件做测试,为了做区分,一般只要稍稍动动文件名即可,MV命令既可以移动文件,也是可以修改文件名的,但批量修改文件名MV做不到,此时,我们可以用rename命令批量修改是蛮不错的 ...
- rename批量修改文件名
批量改名: 如文件,批量修改,把hello去掉[root@localhost wang]# ll-rw-r--r-- 1 root root 0 5月 14 02:36 a.hello.txt-rw- ...
- Linux下批量修改文件名(rename)
原文地址: http://blog.csdn.net/sea_shore/article/details/6102437 1.rename命令批量修改文件名, 其实linux下可以使用别的办法来批量修 ...
- 初学shell,为了练习sed,写了个简单的批量修改文件名的脚本,后来执行时发现系统竟然自带有一个rename命令,顺便也记下了
1 #!/bin/bash 2 <<Comment 3 批量修改文件名的脚本 4 2015/10/24 5 webber 6 Comment 7 ARGS=2 ...
- Linux下find一次查找多个指定类型文件,指定文件或者排除某类文件,在 GREP 中匹配多个关键 批量修改文件名等
http://blog.sina.com.cn/s/blog_62e7fe670101dg9d.html linux下二进制文件查找: strings 0000.ts | grep -o " ...
- linux批量修改文件名的shell脚本
linux中批量修改文件名的shell脚本代码,主要是使用了rename,结合shell,喜欢的朋友可以参考下 使用 rename 命令 ======================== NAME ...
- 用python批量修改文件名
从youtube上当下来百来首mv,每个都需要去掉视频,这还挺好弄得,格式工厂一弄就完了,但是文件名,都带有乱七八糟的*啥的巴拉巴拉的,咋修改啊,几百首总不可能一个一个rename吧 #批量修改文件名 ...
- 批量修改文件名后缀,例如:html修改成HTML
批量修改文件名后缀,例html修改成HTML 把文件后缀名html全部修改成HTML: 例:aa.html aa.HTML #!/bin/bash for file in `ls`;do mv $fi ...
- shell脚本:批量修改文件名
参考链接1:shell脚本:批量修改文件名(删除文件名中字符) 参考链接2:linux shell 字符串操作详解 (长度,读取,替换,截取,连接,对比,删除,位置 ) 参考链接3:每天一个linux ...
随机推荐
- VIM 三种模式和常用命令
引言 大数据开发工作中,周围的同事不是用 VIM 就是 Emacs,你要是用 UltraEdit 或 notepad++ 都不好意思跟人家打招呼...什么插件呀.语法高亮呀.拼写检查呀,能给它开的都给 ...
- RabbitMQ 集群原理
RabbitMQ默认集群原理 rabbitmq 本身是基于erlang编写,erlang语言天生具备分布式的特性(通过同步Erlang集群各节点的erlang cookie实现),RabbiteMQ天 ...
- Springboot2.x入门——helloWorld
Springboot2.x入门--helloWorld 一.简介 1.1 Springboot简介 Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的 ...
- JMeter逻辑控制器完整介绍
JMeter逻辑控制器可以对元件的执行逻辑进行控制,就像编程一样,实现业务需求. JMeter包括了以下逻辑控制器: 一共17种.除了仅一次控制器外,其他控制器下可以嵌套别的种类的逻辑控制器. If ...
- Nginx的配置参数中文说明
Nginx的配置参数中文说明 前言 Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行.其特点是占有内存少,并发能力强 ...
- 从“信息化”到“智慧化”,GVS视声将如何赋能智慧医院?
4月23日-25日,2021年中华医院信息网络大会(CHINC)盛大举办,今年首次携手中国医院建筑与装备创新发展大会,同期同地亮相杭州国际博览中心,塑造了全新的"双引擎"品牌盛会. ...
- 解决:django.core.exceptions.ImproperlyConfigured: Requested setting INSTALLED_APPS, but settings are not 的方法
错误类型: 该错误是在在创建Django工程时出现遇到的错误 完整报错信息:(博文标题输入长度有限制) django.core.exceptions.ImproperlyConfigured: Req ...
- 《精通 ASP.NET Core MVC (第七版)》开始发售
学习 Web 开发技术很难吗?没有适合的学习资料,确实很枯燥,很难.如果有一本如同良师益友的优秀图书辅助,就很轻松,一点也不难! 对于优秀的技术图书来说,必须从读者的角度来编写,而不是从作者的角度来编 ...
- HashMap底层实现原理及面试常见问题
HashMap底层源码分析 1.HashMap底层采用的存储结构 1.在JDK1.7及之前采用的存储结构是数组+链表 2.到了JDK1.8之后采用的是数组+链表+红黑树 2.HashMap实现的原理 ...
- 【NX二次开发】Block UI 指定点
属性说明 属性 类型 描述 常规 BlockID String 控件ID Enable Logical 是否可操作 Group ...