私は、次の.batスクリプトを持っている:Windowsバッチスクリプトによる拡張子付きファイル名の出力方法は?
FOR /f "skip=1" %%x IN ('wmic os get localdatetime') DO IF NOT DEFINED MyDate SET MyDate=%%x
SET today=%MyDate:~0,4%%MyDate:~4,2%%MyDate:~6,2%
SET fileext=".csv"
SET Username=some_user
SET Password=some_password
SET Domain=some_domain
SET LDAPport=3268
SET LDAPAttributeList=sAMAccountName
SET LDAPfilter="(&(objectClass=User)(objectCategory=Person))"
FOR /F "tokens=1,2 delims=|" %%G IN (files_DCs_map.txt) DO (
csvde -f %%G%today%fileext -r %LDAPfilter% -l %LDAPAttributeList% -t %LDAPport% -s %%H -b %Username% %Domain% %Password% -u
)
このスクリプトは、Windows ADドメインコントローラからデータを抽出し、それをファイルに書き込むためにCSVDEユーティリティを使用しています。ファイル名とドメインコントローラIPはファイルfiles_DCs_map.txt
に格納されています。このファイルのサンプル行は次のとおりです。
some_DC|some_IP
スクリプトは機能しますが、不正なファイル名が出力されています。ファイル名は<some_DC><today>.csv
のようにしたい。現在、ファイル名は<some_DC><today>fileext
の形式で出力されています。つまり、変数fileextを正しく解釈していません。たとえば、ファイル名はsome_DC20171128fileext
です。代わりにこのファイル名をsome_DC20171128.csv
にします。どうすればこれを達成できますか?