Как представить символ стрелки вправо, существующий в файле CSV в пакетном файле - PullRequest
0 голосов
/ 16 января 2019

У меня есть командный файл, который заменяет текст в CSV - код был скопирован отсюда ( Заменить определенный текст в CSV через командную строку Мне нужно изменить его, чтобы он заменял символ стрелки вправо в моем входной файл. Код не работает, как показано ниже, поэтому я должен каким-то образом неправильно представлять этот символ / символ.

@echo off
setLocal enableDelayedExpansion

set filename=CARDSHIPPROP.csv
set originalText1=
set "replacedText1=XKXD"

for /f "tokens=*" %%a in ('type %filename%') do (
    set "line=%%a"
if defined line (
    call set "line=%%line:%originalText1%=%replacedText1%%%"
    echo !line!>> CARDSHIPPROP_New.csv
) else (
    echo.
)

)

1 Ответ

0 голосов
/ 17 января 2019

Если ваша цель - отредактировать / заменить файлы специальными символами , это может вам помочь.

Проблема с вашим исходным сценарием в стороне, я не только создал решение, которое работает, но я переработал его с улучшенными функциями исполнения. Текущий скрипт, который вы используете, не сохраняет пустых строк.

@echo off
@setLocal enableDelayedExpansion

set "InputFile=file.csv"
set "OriginalText=Hello There"
set "ReplacedText=Hello > There"

REM | Make sure we only edit the proper line.
FOR /F "delims=" %%n IN ('findstr /n "^" %InputFile%') DO (
    SET "line=%%n"
    SET "Modified=!line:%OriginalText%=%ReplacedText%!"
    SET "Modified=!Modified:*:=!"

    REM | Output the entire edited CSV to a temporary file.
    >> %InputFile%.TEMP ECHO(!Modified!
)

Rem | Delete Original File, Restore New
DEL %InputFile%
REN %InputFile%.TEMP %InputFile%

goto :EOF

Ниже я попытаюсь объяснить, что делает каждая команда SET.

  • SET "line=%%n" - установить текущий %%A в строку. (Это будет строка)
  • SET "Modified=!line:%OriginalText%=%ReplacedText%!" - заменить строку, содержащую %OriginalText%, на соответствующий %ReplaceText% результат.
  • SET "Modified=!Modified:*:=!" - Удалить 1:, 2:, 3:, exc, созданный findstr /n

>> %InputFile%.TEMP ECHO(!Modified! выведет эту претикулярную строку в новый текстовый файл.

Я бы лично предположил, что если вы используете set "String=" с кавычками, любая другая команда set также использует их. Есть некоторые исключения, но в этом случае используйте их!


РЕДАКТИРОВАТЬ:

Так как кажется, что OP запрашивает поддержку специальных символов from & to text, это будет обновленный метод.

Прежде всего это можно сделать с помощью 15-символьной команды powershell. Если вам не нужен чистый пакетный метод и вы хотите сделать его гибридным, я предлагаю это сделать. Однако для получения чистого пакетного раствора продолжите чтение.

Пакетное время трудно обрабатывать специальные символы в функции без каких-либо поломок. Тем не менее, это все еще можно сделать, и я выведу вас на правильный путь.

Ниже приведены два скрипта, ReplaceScript.bat и MainCode.Bat.

  • MainCode.Bat - это ваш сценарий основного пакета. Может быть любым именем.
  • ReplaceScript.bat - это скрипт, к которому мы будем call переходить с MainCode.Bat. This replace script file can be pasted at the bottom of MainCode.Bat` при желании, но из-за размера я предпочитаю его опускать.

Для использования ReplaceScript.bat - Это выглядит следующим образом:

Rem | Usage: call "1" "2" "3" "4" "5"
Rem | call - Calls external script
Rem | "1" - Name of External script
Rem | "2" - File to Edit
Rem | "3" - Text to replace ex: red apple
Rem | "4" - Text to replace to ex: green apple
Rem | "5" - Output file

call "%ReplaceScript%" "%InputTEXT%" "%SEARCHTEXT%" "%REPLACETEXT%" "%OutputTEXT%"

MainCode.bat:

@ECHO OFF

set "InputFile=file.csv"
set "OriginalText=Hello There"
set "ReplacedText=Hello > There"

Rem | Call Replace Script
call "ReplaceScript.bat" "%CustomINI%" "%OriginalText%" "%ReplacedText%"  "%InputFile%.TEMP"

Rem | Delete Original File, Restore New
DEL %InputFile%
REN %InputFile%.TEMP %InputFile%

goto :EOF

ReplaceScript.bat: (НЕ СДЕЛАНО МНОЙ; Уважаемый владелец неизвестен - Если ваш ваш, свяжитесь со мной)

@echo off
setlocal EnableExtensions DisableDelayedExpansion

set "FILE_I=%~1"
set "SEARCH=%~2"
set "REPLAC=%~3"
set "FILE_O=%~4"
set "FLAG=%~5"
if not defined FILE_I exit /B 1
if not defined SEARCH exit /B 1
if not defined FILE_O set "FILE_O=con"
if defined FLAG set "FLAG=#"

for /F "delims=" %%L in ('
    findstr /N /R "^" "%FILE_I%" ^& break ^> "%FILE_O%"
') do (
    set "STRING=%%L"
    setlocal EnableDelayedExpansion
    set "STRING=!STRING:*:=!"
    call :REPL RETURN STRING SEARCH REPLAC %FLAG%
    >> "%FILE_O%" echo(!RETURN!
    endlocal
)

endlocal
exit /B


:REPL  rtn_string  ref_string  ref_search  ref_replac  flag
setlocal EnableDelayedExpansion
set "STR=!%~2!"
set "SCH=!%~3!"
set "RPL=!%~4!"
if not defined SCH endlocal & set "%~1=" & exit /B 1
set "SCH_CHR=!SCH:~,1!"
if not "%~5"=="" set "SCH_CHR="
if "!SCH_CHR!"=="=" set "SCH_CHR=" & rem = terminates search string
if "!SCH_CHR!"==""^" set "SCH_CHR=" & rem " could derange syntax
if "!SCH_CHR!"=="%%" set "SCH_CHR=" & rem % ends variable expansion
if "!SCH_CHR!"=="^!" set "SCH_CHR=" & rem ! ends variable expansion
call :LEN SCH_LEN SCH
call :LEN RPL_LEN RPL
set /A RED_LEN=SCH_LEN-1
set "RES="
:LOOP
call :LEN STR_LEN STR
if not defined STR goto :END
if defined SCH_CHR (
    set "WRK=!STR:*%SCH_CHR%=!"
    if "!WRK!"=="!STR!" (
        set "RES=!RES!!STR!"
        set "STR="
    ) else (
        call :LEN WRK_LEN WRK
        set /A DFF_LEN=STR_LEN-WRK_LEN-1,INC_LEN=DFF_LEN+1,MOR_LEN=DFF_LEN+SCH_LEN
        for /F "tokens=1,2,3 delims=," %%M in ("!DFF_LEN!,!INC_LEN!,!MOR_LEN!") do (
            rem set "RES=!RES!!STR:~,%%M!"
            if defined WRK set "WRK=!WRK:~,%RED_LEN%!"
            if "!STR:~%%M,1!!WRK!"=="!SCH!" (
                set "RES=!RES!!STR:~,%%M!!RPL!"
                set "STR=!STR:~%%O!"
            ) else (
                set "RES=!RES!!STR:~,%%N!"
                set "STR=!STR:~%%N!"
            )
        )
    )
) else (
    if "!STR:~,%SCH_LEN%!"=="!SCH!" (
        set "RES=!RES!!RPL!"
        set "STR=!STR:~%SCH_LEN%!"
    ) else (
        set "RES=!RES!!STR:~,1!"
        set "STR=!STR:~1!"
    )
)
goto :LOOP
:END
if defined RES (
    for /F delims^=^ eol^= %%S in ("!RES!") do (
        endlocal
        set "%~1=%%S"
    )
) else endlocal & set "%~1="
exit /B


:LEN  rtn_length  ref_string
setlocal EnableDelayedExpansion
set "STR=!%~2!"
if not defined STR (set /A LEN=0) else (set /A LEN=1)
for %%L in (4096 2048 1024 512 256 128 64 32 16 8 4 2 1) do (
    if defined STR (
        set "INT=!STR:~%%L!"
        if not "!INT!"=="" set /A LEN+=%%L & set "STR=!INT!"
    )
)
endlocal & set "%~1=%LEN%"
exit /B

Я бы лично предположил, что если вы используете set "String=" с кавычками, любая другая команда set также использует их. Есть некоторые исключения, но в этом случае используйте их!

Для получения дополнительной помощи или понимания любой из команд выполните следующее:

  • call /?
  • set /?
  • for /?
  • if /?
  • goto /?
  • И так далее.
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...