查看單個文章
舊 2016-03-16, 02:07 PM   #5 (permalink)
anglediable
註冊會員
榮譽勳章

勳章總數0
UID - 370825
在線等級: 級別:0 | 在線時長:2小時 | 升級還需:3小時
註冊日期: 2016-02-23
文章: 3
精華: 0
現金: 5 金幣
資產: 5 金幣
預設

引用:
作者: getter 查看文章
基本使用 DOS/cmd 命令的 ren 給予檔案重新命名

命令語法:ren [舊檔名] [新檔名]

比方說舊檔名 123.txt 要改名成 abc.txt

就是 C:\>ren 123.txt abc.txt

可以使用 * 或 ? 的萬用字元,來找尋同類型檔案給予重新命名
如C:\>ren 123-*.txt abc-*.txt

表示以 123- 開頭的檔案,改名成 abc- 開頭

* 號表示所有位數符號的萬用類型,以 123-* 來說 123-123456 跟 123-123 都會被找到
? 號表示一位數符號的萬用類型,以 123-? 來說 123-1 跟 123-a 才會被找到,因此
 123-123456 跟 123-123 會被忽略。可以利用 ? 的數量增減,來指定找尋檔案的名稱的長度。

當檔案名稱中,若有 " " 空白字元時,必須使用 "" 來把整個檔名給予包起來,如
"2015 0210 ?????????? ???? X 02".* 或是 "2015 0210 ?????????? 0746 A 02".*

不然以 DOS/cmd 命令來說, " " 空白字元是給命令用來是區別語法中來源檔案名稱、參數等
的分隔符號,若是以

ren 2015 0210 ?????????? ???? X 02.* 2015 0210 ?????????? 0746 A 02.*

ren 看到的 2015 跟 0210 會分別當成舊檔名跟新檔名,之後的會當成其他的參數或奇怪的東西
DOS/cmd 系統會回覆 語法錯誤。

據此 ren "2015 0210 ?????????? ???? X 02".* "2015 0210 ?????????? 0746 A 02".*
把檔名用 "" 號包起來才是解決檔名中有包含空白字元的方式。

-------------------------------------------------------------------------------------------
據此迪西以 ren "2015 0210 ?????????? ???? X 02".* "2015 0210 ?????????? 0746 A 02".*

來設計批次檔

? 號部份即是不會被改變,且被 ren 找到複數檔案並重新命名的部份


批次檔中迪西給了三個變數

YMD: 據您提供的資訊,這部份因該是年月日,可以作為找尋特定檔案的條件之一
OLD: 據您提供的資訊,這部份因該是檔名要變更的部份結尾檔名,可以作為找尋特定檔案的條件之二
NEW: 這個部份就是,提供要改變的檔名。

使用語法:ren-4x [找尋特定檔案的開頭年月日] [找尋特定檔案的結尾部份] [要變更的新名稱]
範例 C:\>ren-4x "2015 0210" "x 02" "0746 A 02"


接下來就要靠您自己來調整,是否符合使用的需求了
版大,您好,我花了點時間來研究
後來發現,可能是我有語意不清的地方
我是想改文字文件的內容,不是修改檔名
不過還是非常感謝您的熱心回覆
我還要再想想這段批次檔要怎麼寫~

文字文件內容如下虛線之間
-----------------------------------------------
2015 1217 1050306737 0742 X 01
2015 1217 4000411066 0743 X 01
2015 1217 4004046474 0744 X 01
2015 1217 4000370554 0745 X 01
2015 1217 0950025741 0745 X 01
2015 1217 4004466938 0745 X 01
2015 1217 4000531722 0746 A 01
2015 1217 4000531002 0746 A 01
2015 1217 5040551727 0746 A 01
2015 1217 7000581994 0746 A 01
-----------------------------------------------

希望能判斷
22-25的數字如『小於』0746則修改為0746
及第27位如果是X則修改為A
若該行條件都符合,則不做變動

修改結果如下虛線之間
-----------------------------------------------
2015 1217 1050306737 0746 A 01
2015 1217 4000411066 0746 A 01
2015 1217 4004046474 0746 A 01
2015 1217 4000370554 0746 A 01
2015 1217 0950025741 0746 A 01
2015 1217 4004466938 0746 A 01
2015 1217 4000531722 0746 A 01
2015 1217 4000531002 0746 A 01
2015 1217 5040551727 0746 A 01
2015 1217 7000581994 0746 A 01
-----------------------------------------------
anglediable 目前離線  
送花文章: 2, 收花文章: 1 篇, 收花: 1 次
回覆時引用此帖
向 anglediable 送花的會員:
羅迪 (2016-03-18)
感謝您發表一篇好文章