批次修改文字文件
請問一下
小弟有份文字文件想批次修改其中固定幾個字元的文字 資料每天都會產出上百筆,但字元位置固定 2015 0210 2000335898 0713 X 02 2015 0210 2050263793 0719 X 02 2015 0210 2000801866 0730 X 02 2015 0210 2004289626 0735 X 02 2015 0210 2950853949 0736 X 02 如上面,每一行的22-25字元 須判斷如該字元小於0746,則須修改為0746 及第27字元如為X,則須修改為A 修改後結果如下 2015 0210 2000335898 0746 A 02 2015 0210 2050263793 0746 A 02 2015 0210 2000801866 0746 A 02 2015 0210 2004289626 0746 A 02 2015 0210 2950853949 0746 A 02 請問我該怎麼寫呢?謝謝~ |
基本命令如下:
ren "2015 0210 ?????????? ???? X 02".* "2015 0210 ?????????? 0746 A 02".* 語法:
@echo off |
引用:
好像有點複雜,小弟先研究一下,有不懂的再請教您,非常感謝!:on_45: |
基本使用 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 ----------------------------------------------- |
要修改文件內容 ... 用批次檔本身來說,難解或是無解 ...
只能透過文字文件的編輯器,以「找尋、替代」的功能來處理 |
所有時間均為台北時間。現在的時間是 10:29 AM。 |
Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.
『服務條款』
* 有問題不知道該怎麼解決嗎?請聯絡本站的系統管理員 *