【发布时间】:2018-02-25 15:21:49
【问题描述】:
我有多个要重命名的 mp3 文件来组织它们。它们中的大多数都有类似的格式:数字 0,后跟一个数字 (1:9),一个空格,然后是 mp3 文件名。它们看起来像这样:
head(files)
[1] "01 50 Cent - Candy Shop.mp3"
[2] "01 50 Cent - Fresh '83.mp3"
[3] "01 Akon ft Eminem - Smack That.mp3"
[4] "01 Akon ft Snoop Dog - I Wanna Love You.mp3"
[5] "01 Aldo Ranks - Baila.mp3"
[6] "01 Aldo Ranks - El Alicate.mp3"
或
head(files[1098:1102])
[1] "1-01 Spragga Benz - She Nuh Ready Yet.mp3"
[2] "1-01 Tal Bachman - Darker Side Of Blue.mp3"
[3] "1-01 When Love Takes Over (feat. Kelly Rowland).mp3"
[4] "1-02 Big Boy - Voz Sensual.m4a"
[5] "1-02 Come Out And See.mp3"
为简单起见,我的工作目录是包含这些文件的文件夹。
重命名这些文件的有效方法是什么?可能使用诸如substr、grep 或其他一些正则表达式?我应该写一个函数吗?
我尝试将文件名存储在名为 files 的变量中,但效率不高,因为对其中元素的更改不会反映在我的工作目录中。
任何建议>
【问题讨论】:
-
新名称是什么? (顺便说一句,
substr不使用正则表达式。) -
例如,如果当前名称是“01 50 Cent - Fresh '83.mp3”,我想将其更改为“50 Cent - Fresh '83.mp3”。
-
参见
sub命令,例如。sub("[0-9-]+\\s-*", "", "01 50 Cent - Candy Shop.mp3")