史萊姆論壇

史萊姆論壇 (http://forum.slime.com.tw/)
-   程式語言討論區 (http://forum.slime.com.tw/f76.html)
-   -   批次修改文字文件 (http://forum.slime.com.tw/thread283859.html)

anglediable 2016-03-10 09:00 AM

批次修改文字文件
 
請問一下
小弟有份文字文件想批次修改其中固定幾個字元的文字
資料每天都會產出上百筆,但字元位置固定

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

請問我該怎麼寫呢?謝謝~

getter 2016-03-11 01:48 PM

基本命令如下:

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

語法:

@echo off
::help
::YMD = 找尋欲變更檔名的開頭年月日,輸入 "2015 0210"
::OLD = 找尋欲變更檔名的結尾,輸入 "X 02"
::NEW = 欲變更檔名的結尾,輸入 "0746 A 02"
::使用範例 C:\>ren-4x "2015 0210" "x 02" "0746 A 02"

:main
set "YMD=%1"
set "YMD=%YMD:~1,9%"
set "OLD=%2"
set "OLD=%OLD:~1,4%"
set "NEW=%3"
set "NEW=%NEW:~1,9%"
ren "%YMD% ?????????? ???? %OLD%".*  "%YMD% ?????????? %NEW%".*
::echo "%YMD% ?????????? ???? %OLD%".*  "%YMD% ?????????? %NEW%".*
pause


anglediable 2016-03-11 04:58 PM

引用:

作者: getter (文章 2358152)
基本命令如下:

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

語法:

@echo off
::help
::YMD = 找尋欲變更檔名的開頭年月日,輸入 "2015 0210"
::OLD = 找尋欲變更檔名的結尾,輸入 "X 02"
::NEW = 欲變更檔名的結尾,輸入 "0746 A 02"
::使用範例 C:\>ren-4x "2015 0210" "x 02" "0746 A 02"

:main
set "YMD=%1"
set "YMD=%YMD:~1,9%"
set "OLD=%2"
set "OLD=%OLD:~1,4%"
set "NEW=%3"
set "NEW=%NEW:~1,9%"
ren "%YMD% ?????????? ???? %OLD%".*  "%YMD% ?????????? %NEW%".*
::echo "%YMD% ?????????? ???? %OLD%".*  "%YMD% ?????????? %NEW%".*
pause



好像有點複雜,小弟先研究一下,有不懂的再請教您,非常感謝!:on_45:

getter 2016-03-12 01:02 AM

基本使用 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"


接下來就要靠您自己來調整,是否符合使用的需求了

anglediable 2016-03-16 02:07 PM

引用:

作者: getter (文章 2358193)
基本使用 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
-----------------------------------------------

getter 2016-03-20 01:07 PM

要修改文件內容 ... 用批次檔本身來說,難解或是無解 ...

只能透過文字文件的編輯器,以「找尋、替代」的功能來處理


所有時間均為台北時間。現在的時間是 10:29 AM

Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.

『服務條款』

* 有問題不知道該怎麼解決嗎?請聯絡本站的系統管理員 *


SEO by vBSEO 3.6.1