2021.05.17
こんにちは、クラウドソリューション部の平石です。
日々の開発業務で大量のテキストファイルを編集(置換)して作成する必要がある場合、どのように作成されているでしょうか。
先日、業務で大量のテキストファイルを作成する必要がありましたが、
使用するツールによって効率がたいぶ異なりましたので紹介したいと思います。
★
一見簡単なバッチファイルを作れば出来そうなのですが、
Windows でよくある文字コードと改行コードの問題で実現に意外と手間がかかりました。
テキスト編集といえば UNIX 系の perl や sed , awk などを使用するのがスマートですが、
ソフトのインストールも出来ない環境を考慮し、今回は Windows に標準搭載のバッチファイルと PowerShell と VBScript を使用してコーディングした結果を比較したいと思います。

TestMetaDataAAA.koumokuLLL_291.md

今回は、上記のベースとなるテキストファイルに対して
仕様通りの文字列の置換を行い、ファイルに出力したいと思います。
それぞれの手法で実行した結果の出力ファイルは、以下の通りとなります。
全ての実行結果で同じ出力内容です。
文字列が置換されていて、文字コードがUTF-8で改行コードがLFとなっています。



それぞれのコーディング結果や問題点をまとめると以下のようになります。
| バッチファイル | PowerShell | VBScript | |
|---|---|---|---|
| 行数(コメント除く) | 55行 | 19行 | 51行 |
| 実装時間 | 6h | 4h | 2h |
| 問題点 |
|
|
|
どのコーディング結果も、テキストの置換処理は簡単に出来ましたが
やはり文字コードと改行コードの指定にはひと手間必要でした。
また、それぞれの文法を調べる時間も含めていますので
言語の理解度によっても実装時間はたいぶ変わってくると思います。
最後に、それぞれのソースコードと実行方法は以下の通りですので参考にされて下さい。
chcp 65001
rem @echo off
set BEFORE_STRING=_291
set BEFORE_STRING2=TestvalueAA__c
set INPUT_FILE=TestMetaDataAAA.koumokuLLL_291.md
set OUTPUT_FILE=TestMetaDataAAA.koumokuLLL
set name_295=TestvalueMM__c
set name_296=TestvalueOO__c
set name_297=TestvaluePP__c
set LF=^
setlocal enabledelayedexpansion
rem ファイル数だけ繰り返して文字列を置換
set i=295
:FOREACH_MD
set it=!name_%i%!
if defined it (
for /f "delims=" %%a in (%INPUT_FILE%) do (
set line=%%a
set line=!line:%BEFORE_STRING%=_%i%!
set line=!line:%BEFORE_STRING2%=%it%!
echo !line!>>.\tmp\%OUTPUT_FILE%_%i%.md
)
set /a i+=1
goto :FOREACH_MD
)
else (
goto :COM_MD2
)
:COM_MD2
rem ファイル数だけ繰り返して改行コードをLFに置換
set i=295
:FOREACH_MD2
if exist .\tmp\%OUTPUT_FILE%_%i%.md (
for /f "delims=" %%1 in ('find /n /v "" .\tmp\%OUTPUT_FILE%_%i%.md') do (
set LINE=%%1
setlocal enabledelayedexpansion
<NUL set LINE=!LINE:*]=!!LF!
echo !LINE! >> .\tmp2\%OUTPUT_FILE%_%i%.md
endlocal
)
set /a i+=1
goto :FOREACH_MD2
)
else (
goto :COM_MD3
)
rem ファイル数だけ繰り返して空行と不要な行を除外
:COM_MD3
set i=295
:FOREACH_MD3
set OUTPUT_FILE=TestMetaDataAAA.koumokuLLL_%i%.md
if exist .\tmp2\%OUTPUT_FILE% (
findstr /v /r /c:"^\ *$" .\tmp2\%OUTPUT_FILE% | findstr /v /r /c:"----------" > .\output\%OUTPUT_FILE%
set /a i+=1
goto :FOREACH_MD3
)
endlocal
上記のバッチファイルを文字コードSJIS、改行コードをCRLFで保存して同じフォルダに置換のベースとなるテキストファイルを保存します。makefile.batをダブルクリックまたはコマンドプロンプトから実行するとoutputフォルダ以下にファイルが出力されます。


$BEFORE_STRING="_291"
$BEFORE_STRING2="TestvalueAA__c"
$INPUT_FILE="TestMetaDataAAA.koumokuLLL_291.md"
$OUTPUT_FILE="TestMetaDataAAA.koumokuLLL"
$map = @{
295 = "TestvalueMM__c";
296 = "TestvalueOO__c";
297 = "TestvaluePP__c";
}
# ファイル数だけ繰り返しforeach ($Ke
y in $map.Keys) {
$afterTxt = "_"+$Key
$name = $map[$Key]
((Get-Content -Path $INPUT_FILE -Encoding UTF8) -join "`n") + "`n" `
| % { $_ -replace $BEFORE_STRING, $afterTxt } `
| % { $_ -replace $BEFORE_STRING2, $name } ` | % {
[Text.Encoding]::UTF8.GetBytes($_) } `
| Set-Content -Path .\output\TestMetaDataAAA.koumokuLLL_$Key.md -Encoding Byte
}
上記の実行ファイルを保存して、同じフォルダに置換のベースとなるテキストファイルを保存します。
makeMeta.ps1を右クリックし、メニューから「powershellで実行」を選択すると
outputフォルダ以下にファイルが出力されます。


Option Explicit
Dim objStream
Dim tmpStream
Dim strScriptPath
Dim strOpenFile
Dim strWriteFile
Dim objWriteStream
Dim strText
Dim strText1
Dim strText2
Dim adTypeBinary : adTypeBinary = 1
Dim adTypeText : adTypeText = 2
Dim intTxt(2) '置換対象の文字列
intTxt(0) = "TestvalueMM__c"
intTxt(1) = "TestvalueOO__c"
intTxt(2) = "TestvaluePP__c"
Dim intNum : intNum = 295
'--------------------------------------
' 実行パスを取得
'--------------------------------------
strScriptPath = Replace(WScript.ScriptFullName,WScript.ScriptName,"")
'--------------------------------------
' ファイル数だけ繰り返し
'--------------------------------------
Do While intNum < 298
Set objStream = CreateObject("ADODB.Stream")
objStream.Charset = "UTF-8"
objStream.Open
Set tmpStream = CreateObject("ADODB.Stream")
tmpStream.Type = adTypeText
tmpStream.Charset = "UTF-8"
tmpStream.Open
'--------------------------------------
' strWriteFileは書き込むファイル
'--------------------------------------
strWriteFile = "TestMetaDataAAA.koumokuLLL_" & Cstr(intNum) & ".md"
'--------------------------------------
' strOpenFileは読込むファイル
'--------------------------------------
strOpenFile = "TestMetaDataAAA.koumokuLLL_291.md"
objStream.LoadFromFile strScriptPath & strOpenFile
'--------------------------------------
' 読み込み処理
'--------------------------------------
Do Until objStream.EOS = True
'--------------------------------------
' ファイルを1行ずつ読込み置換
'--------------------------------------
strText = objStream.ReadText(-1)
strText1 = Replace(strText,"_291","_" & intNum)
strText2 = Replace(strText1,"TestvalueAA__c", intTxt(intNum-295))
'--------------------------------------
' tmpStreamは一時書き込みファイル
'--------------------------------------
tmpStream.WriteText strText2, 0
intNum = intNum + 1
Loop
'--------------------------------------
' BOMなしでstrWriteFileに書き込む
'--------------------------------------
tmpStream.Position = 0
tmpStream.Type = adTypeBinary
tmpStream.Position = 3
Dim bin : bin = tmpStream.Read()
tmpStream.Close
Dim outStream : Set outStream = CreateObject("ADODB.Stream")
outStream.Type = adTypeBinary
outStream.Open()
outStream.Write(bin)
outStream.SaveToFile strScriptPath & "output\" & strWriteFile, 2
outStream.Close()
Loop
Set objStream = NothingSet o
utStream = Nothing
Set tmpStream = Nothing
上記の実行ファイルを保存して、同じフォルダに置換のベースとなるテキストファイルを保存します。
cscriptTest.vbsをダブルクリックすると
outputフォルダ以下にファイルが出力されます。


2026.01.26
10年使った炊飯器が大きな故障はないものの、水漏れや炊き上がりの変化などから寿命を意識し、買い替えを検討。ネット検索では情報過多に戸惑い、家電量販店で最新事情を確認する流れを選びました。メーカーは保温性能と使い慣れた考え方を重視し、象印マホービンを継続候補に。価格帯や世代差、型落ち上位モデルの魅力を整理し、価格推移を見ながら最適な購入タイミングを探っています。
2026.01.23
ダッシュボードの目標管理を、もっと効率的に行いたい方におすすめの記事です。Salesforceの「動的ゲージグラフ」は、ユーザーやレコードの項目を目標値として参照できるため、複数のダッシュボードで同じ目標を使っている場合でも、元データを一か所更新するだけで反映される点が特長です。具体的な仕組みから具体的な作成手順、活用時のポイントまでを分かりやすく解説しています。KPI管理や目標達成率の可視化に役立つ内容となっております。
2026.01.19
疲れたときは「寝る」だけで十分だと思っていませんか?本記事では、科学的な視点から休養を7つのタイプに分類し、運動や人との交流、環境の変化など、行動することで回復につながる方法を紹介しています。自分に合った休養の取り方を知り、日々の疲労と上手に付き合うためのヒントをお届けします。
2026.01.14
2025年10月に開催されたさがねんりんピック2025 ラージボール卓球交流大会に混合ダブルスA級で参加した体験を振り返ります。予選リーグを2位で通過し、決勝トーナメントでは準決勝まで進出。苦手とするカットマンペアとの対戦を通じて、戦術理解や練習の重要性を実感しました。結果だけでなく、試合を通して感じた反省や今後の反省、健康と向き合いながら競技を続けていく思いについても触れています。