
Я пытаюсь создать .bat-скрипт для фильтрации строк в .txt-файлах и форматирования вывода в .json-файл.
Мои файлы .txt содержат такие строки:
Server: http://viphome1.com:33000/c/
MAC: 00:1a:79:91:a6:cf
Vence:July 15, 2022, 11:35 pm
MAC: 00:1a:79:92:1a:b1
Vence:May 6, 2022, 12:35 am
Целевой файл .json — это файл для настройки программы, а строки, отфильтрованные в желаемом макете, будут выглядеть следующим образом:
[
{
"Name": "any",
"Address": "http://viphome1.com:33000/c/",
"Mac": "00:1a:79:91:a6:cf"
},
{
"Name": "any2",
"Address": "http://viphome1.com:33000/c/",
"Mac": "00:1a:79:ad:83:b1"
}
]
Мой скрипт.bat:
@ECHO OFF
SETLOCAL
(
FOR /f "tokens=* delims=:," %%a IN (C:\Users\dom19\Desktop\first.txt) DO (
ECHO(
)
)>Accounts.json
TYPE Accounts.json
Я изучал только HTML и CSS, никогда не делал пакетные файлы, и буду благодарен за любую помощь. Спасибо.
решение1
Хотя я не очень хорошо разбираюсь в макете и других аспектах формата .json, я создал bat, который генерирует некоторые файлы в макете, указанном в вопросе, и выполняет обработку, чтобы отформатировать строки для ожидаемого вывода (или того, что я понял, когда это было меньше).
- Это мой bat, который сначала создает те же файлы, что и ваш, а затем обрабатывает/возвращает json..
@echo off
setlocal enableDelayedExpansion
cd /d "%~dp0" & >.\Target.json echo[[
>.\File_01.txt ^
(
echo\Server: http://viphome1.com:33000/a/
echo\MAC: 00:1a:79:91:a6:cf
echo\Vence:July 15, 2022, 11:35 pm
echo\MAC: 00:1a:79:92:1a:b1
echo\Vence:May 6, 2022, 12:35 am
)
>.\File_02.txt ^
(
echo\Server: http://viphome1.com:33000/b/
echo\MAC: 0a:1a:79:91:a6:cf
echo\Vence:July 15, 2022, 11:35 pm
echo\MAC: 0b:1a:79:92:1a:b1
echo\Vence:May 7, 2022, 12:35 am
)
>.\File_03.txt ^
(
echo\Server: http://viphome1.com:33000/c/
echo\MAC: 0c:1a:79:91:a6:cf
echo\Vence:July 15, 2022, 11:35 pm
echo\MAC: 0d:1a:79:92:1a:b1
echo\Vence:May 8, 2022, 12:35 am
)
>.\File_04.txt ^
(
echo\Server: http://viphome1.com:33000/d/
echo\MAC: 0e:1a:79:91:a6:cf
echo\Vence:July 15, 2022, 11:35 pm
echo\MAC: 0f:1a:79:92:1a:b1
echo\Vence:May 9, 2022, 12:35 am
)
set _cnt=<nul & for %%G in (.\*.txt)do <con: >>.\Target.json (
echo\ ^{& for /f useback^tokens^=1*delims^=^":^ %%i in (
`findstr/v "Vence" ^< "%%~G"`)do if not "!_mac!" == "" (
echo\ ^{
set _mac=<nul
echo; !_name!
echo; !_address!
echo; "%%~i": "%%~j"
) else if /i "%%~i" == "Server" (
set /a "_cnt+=1+0"
set "_n=00000!_cnt!"
set "_address="Address": "%%~j","
echo; "Name": "Any_!_n:~-6!",
echo; !_address!
) else (
set "_mac=?"
set /a "_cnt+=1+0"
set "_n=00000!_cnt!"
echo; "%%~i": "%%~j"
set "_name="Name": "Any_!_n:~-6!","
echo; ^},
)
echo\ ^}
)
>>.\Target.json echo;] & endlocal | type .\Target.json
Вам понадобится более одного цикла for для выполнения форматирования/манипулирования строками/строками и получения вашего файла .json.
Мои тестовые файлы (название и содержание):
.\File_01.txt:
Server: http://viphome1.com:33000/a/
MAC: 00:1a:79:91:a6:cf
Vence:July 15, 2022, 11:35 pm
MAC: 00:1a:79:92:1a:b1
Vence:May 6, 2022, 12:35 am
.\File_02.txt:
Server: http://viphome1.com:33000/b/
MAC: 0a:1a:79:91:a6:cf
Vence:July 15, 2022, 11:35 pm
MAC: 0b:1a:79:92:1a:b1
Vence:May 7, 2022, 12:35 am
.\File_03.txt:
Server: http://viphome1.com:33000/c/
MAC: 0c:1a:79:91:a6:cf
Vence:July 15, 2022, 11:35 pm
MAC: 0d:1a:79:92:1a:b1
Vence:May 8, 2022, 12:35 am
.\File_04.txt:
Server: http://viphome1.com:33000/d/
MAC: 0e:1a:79:91:a6:cf
Vence:July 15, 2022, 11:35 pm
MAC: 0f:1a:79:92:1a:b1
Vence:May 9, 2022, 12:35 am
- Target.json полученный контент
[
{
"Name": "Any_000001",
"Address": "http://viphome1.com:33000/a/",
"MAC": "00:1a:79:91:a6:cf"
},
{
"Name": "Any_000002",
"Address": "http://viphome1.com:33000/a/",
"MAC": "00:1a:79:92:1a:b1"
}
{
"Name": "Any_000003",
"Address": "http://viphome1.com:33000/b/",
"MAC": "0a:1a:79:91:a6:cf"
},
{
"Name": "Any_000004",
"Address": "http://viphome1.com:33000/b/",
"MAC": "0b:1a:79:92:1a:b1"
}
{
"Name": "Any_000005",
"Address": "http://viphome1.com:33000/c/",
"MAC": "0c:1a:79:91:a6:cf"
},
{
"Name": "Any_000006",
"Address": "http://viphome1.com:33000/c/",
"MAC": "0d:1a:79:92:1a:b1"
}
{
"Name": "Any_000007",
"Address": "http://viphome1.com:33000/d/",
"MAC": "0e:1a:79:91:a6:cf"
},
{
"Name": "Any_000008",
"Address": "http://viphome1.com:33000/d/",
"MAC": "0f:1a:79:92:1a:b1"
}
]
- Сохраните этот код как
any_name.cmd
и попробуйте запустить в той же папке, где у вас находятся файлы .txt.
@echo off
setlocal enableDelayedExpansion
cd /d "%~dp0" & >.\Target.json echo[[
set^ _cnt=<nul& for %%G in (.\*.txt)do <con: >>.\Target.json (
echo\ ^{& for /f useback^tokens^=1*delims^=^":^ %%i in (
`findstr/v "Vence" ^< "%%~G"`)do if not "!_mac!" == "" (
echo\ ^{
set _mac=<nul
echo; !_name!
echo; !_address!
echo; "%%~i": "%%~j"
) else if /i "%%~i" == "Server" (
set /a "_cnt+=1+0"
set "_n=00000!_cnt!"
set "_address="Address": "%%~j","
echo; "Name": "Any_!_n:~-6!",
echo; !_address!
) else (
set "_mac=?"
set /a "_cnt+=1+0"
set "_n=00000!_cnt!"
echo; "%%~i": "%%~j"
set "_name="Name": "Any_!_n:~-6!","
echo; ^},
)
echo\ ^}
)
>>.\Target.json echo;] & endlocal | type .\Target.json