2013-04-07 2 views
0

У меня есть пакетный файл, который загружает содержимое каталога загрузки изображений из портала администратора и генерирует текстовый файл, содержащий атрибут img src для каждого изображения.Ищете пакетный файл для вставки новых строк в текстовый файл

В этот момент каждый из этих текстовых файлов содержит атрибуты для 20+ изображений, которые затем я вставляю в div на странице aspx через код C# позади файла.

Я переключаюсь на новый макет, поэтому я должен добавить </l i> < l i> после каждых 3 строк.

Я пытаюсь выяснить, как использовать пакетный файл, чтобы прочитать текст, содержащий IMG SRC и вставьте этот код через каждые 3 строки, но я совершенно lost.bat

ответ

1
@ECHO OFF 
SETLOCAL 
SET count=0 
SET injectevery=3 
FOR /f "delims=" %%Z IN ('type njacpm.txt^|findstr /n "^"') DO (
SET /a count+=1 
SET line=%%Z 
SETLOCAL ENABLEDELAYEDEXPANSION 
ECHO(!line:*:=! 
IF !count!==%injectevery% ECHO.^</li^>^<li^> 
ENDLOCAL 
SET /a count=count %% %injectevery% 
) 

Примечание: 20130407-1417 регулируется за dbenham комментарий

Теперь - если NJACPM.TXT содержит

=============================== 
line of text 1 

line 3 - 2 was empty 
: and this behind colon 
but this doesn't 
A line of ] many <and>varied %poison^characters | like "," and so on 
another line 
and another 

now a real test %path% and !path! 
what say you now? 
=============================== 

И выход:

=============================== 
line of text 1 

line 3 - 2 was empty 
</li><li> 
: and this behind colon 
but this doesn't 
A line of ] many <and>varied %poison^characters | like "," and so on 
</li><li> 
another line 
and another 

</li><li> 
now a real test %path% and !path! 
what say you now? 
=============================== 

НО:

серьезных Дозаторы поймут ... и я попытался с & тоже ... работали!

  • njacpm.txt? Now Just A Cotton-Pickin 'Minute ...
+1

+ 1, Нет необходимости устанавливать EMPTY и тестировать, если они определены. Просто замените эти 2 строки на 'echo (! Line: *: =!'. Я использую 'echo (' вместо 'echo.', потому что' echo.' может выйти из строя в зависимости от на каком тексте следует. 'echo (' always works. – dbenham

+0

О, да! Блестящий! – Magoo

+0

работал как шарм, просто перенаправил этот вывод там, где он мне нужен, и я настроен. Огромное спасибо. – sgates3414

2

Это может быть сделано достаточно легко с чистую партию, используя FOR/F для циклического перехода по строкам, SET/A для увеличения счетчика, а также замедленное расширение или CALL для подпрограммы вместе с инструкцией IF, чтобы добавить дополнительный текст в каждую третью строку.

Но я бы использовал служебную программу, которую я уже написал, которая выполняет поиск и замену регулярных выражений. Это гибридный JScript/пакетный скрипт REPL.BAT, который работает на любой современной платформе Windows. Он очень прост в использовании, если вы знаете регулярные выражения, и он намного быстрее, чем любое чистое пакетное решение.

У этого есть опция M (многострочная), которая позволяет искать и заменять разрывы строк и опцию X (eXtended substitution), которая позволяет escape-последовательности в заменяющем тексте.

Предполагая, что REPL.BAT находится либо в вашей текущей папке, либо где-то внутри вашего PATH, тогда следующий простой скрипт вставляет </li><li> в качестве новой строки после каждой третьей строки в оригинале.

EDIT:parametized "Inject каждый" рассчитывать, и изменил \n к \r\n в строке замены

@echo off 
setlocal 
set "file=test.txt" 
set "count=3" 
<"%file%" call repl "((.*\n){%count%})" "$1</li><li>\r\n" mx >"%file%.new" 
move /y "%file%.new" "%file%" >nul 

Вот файл REPL.BAT, что позволяет выше скрипт для работы , В нее встроена полная документация.

@if (@X)==(@Y) @end /* Harmless hybrid line that begins a JScript comment 

::************ Documentation *********** 
::: 
:::REPL Search Replace [Options [SourceVar]] 
:::REPL /? 
::: 
::: Performs a global search and replace operation on each line of input from 
::: stdin and prints the result to stdout. 
::: 
::: Each parameter may be optionally enclosed by double quotes. The double 
::: quotes are not considered part of the argument. The quotes are required 
::: if the parameter contains a batch token delimiter like space, tab, comma, 
::: semicolon. The quotes should also be used if the argument contains a 
::: batch special character like &, |, etc. so that the special character 
::: does not need to be escaped with ^. 
::: 
::: If called with a single argument of /? then prints help documentation 
::: to stdout. 
::: 
::: Search - By default this is a case sensitive JScript (ECMA) regular 
:::   expression expressed as a string. 
::: 
:::   JScript syntax documentation is available at 
:::   http://msdn.microsoft.com/en-us/library/ae5bf541(v=vs.80).aspx 
::: 
::: Replace - By default this is the string to be used as a replacement for 
:::   each found search expression. Full support is provided for 
:::   substituion patterns available to the JScript replace method. 
:::   A $ literal can be escaped as $$. An empty replacement string 
:::   must be represented as "". 
::: 
:::   Replace substitution pattern syntax is documented at 
:::   http://msdn.microsoft.com/en-US/library/efy6s3e6(v=vs.80).aspx 
::: 
::: Options - An optional string of characters used to alter the behavior 
:::   of REPL. The option characters are case insensitive, and may 
:::   appear in any order. 
::: 
:::   I - Makes the search case-insensitive. 
::: 
:::   L - The Search is treated as a string literal instead of a 
:::    regular expression. Also, all $ found in Replace are 
:::    treated as $ literals. 
::: 
:::   E - Search and Replace represent the name of environment 
:::    variables that contain the respective values. An undefined 
:::    variable is treated as an empty string. 
::: 
:::   M - Multi-line mode. The entire contents of stdin is read and 
:::    processed in one pass instead of line by line.^anchors 
:::    the beginning of a line and $ anchors the end of a line. 
::: 
:::   X - Enables extended substitution pattern syntax with support 
:::    for the following escape sequences: 
::: 
:::    \\  - Backslash 
:::    \b  - Backspace 
:::    \f  - Formfeed 
:::    \n  - Newline 
:::    \r  - Carriage Return 
:::    \t  - Horizontal Tab 
:::    \v  - Vertical Tab 
:::    \xnn - Ascii (Latin 1) character expressed as 2 hex digits 
:::    \unnnn - Unicode character expressed as 4 hex digits 
::: 
:::    Escape sequences are supported even when the L option is used. 
::: 
:::   S - The source is read from an environment variable instead of 
:::    from stdin. The name of the source environment variable is 
:::    specified in the next argument after the option string. 
::: 

::************ Batch portion *********** 
@echo off 
if .%2 equ . (
    if "%~1" equ "/?" (
    findstr "^:::" "%~f0" | cscript //E:JScript //nologo "%~f0" "^:::" "" 
    exit /b 0 
) else (
    call :err "Insufficient arguments" 
    exit /b 1 
) 
) 
echo(%~3|findstr /i "[^SMILEX]" >nul && (
    call :err "Invalid option(s)" 
    exit /b 1 
) 
cscript //E:JScript //nologo "%~f0" %* 
exit /b 0 

:err 
>&2 echo ERROR: %~1. Use REPL /? to get help. 
exit /b 

************* JScript portion **********/ 
var env=WScript.CreateObject("WScript.Shell").Environment("Process"); 
var args=WScript.Arguments; 
var search=args.Item(0); 
var replace=args.Item(1); 
var options="g"; 
if (args.length>2) { 
    options+=args.Item(2).toLowerCase(); 
} 
var multi=(options.indexOf("m")>=0); 
var srcVar=(options.indexOf("s")>=0); 
if (srcVar) { 
    options=options.replace(/s/g,""); 
} 
if (options.indexOf("e")>=0) { 
    options=options.replace(/e/g,""); 
    search=env(search); 
    replace=env(replace); 
} 
if (options.indexOf("l")>=0) { 
    options=options.replace(/l/g,""); 
    search=search.replace(/([.^$*+?()[{\\|])/g,"\\$1"); 
    replace=replace.replace(/\$/g,"$$$$"); 
} 
if (options.indexOf("x")>=0) { 
    options=options.replace(/x/g,""); 
    replace=replace.replace(/\\\\/g,"\\B"); 
    replace=replace.replace(/\\b/g,"\b"); 
    replace=replace.replace(/\\f/g,"\f"); 
    replace=replace.replace(/\\n/g,"\n"); 
    replace=replace.replace(/\\r/g,"\r"); 
    replace=replace.replace(/\\t/g,"\t"); 
    replace=replace.replace(/\\v/g,"\v"); 
    replace=replace.replace(/\\x[0-9a-fA-F]{2}|\\u[0-9a-fA-F]{4}/g, 
    function($0,$1,$2){ 
     return String.fromCharCode(parseInt("0x"+$0.substring(2))); 
    } 
); 
    replace=replace.replace(/\\B/g,"\\"); 
} 
var search=new RegExp(search,options); 

if (srcVar) { 
    WScript.Stdout.Write(env(args.Item(3)).replace(search,replace)); 
} else { 
    while (!WScript.StdIn.AtEndOfStream) { 
    if (multi) { 
     WScript.Stdout.Write(WScript.StdIn.ReadAll().replace(search,replace)); 
    } else { 
     WScript.Stdout.WriteLine(WScript.StdIn.ReadLine().replace(search,replace)); 
    } 
    } 
} 
+0

+1, очень приятно и полезно – Endoro

1

Это может быть сделано достаточно легко с чистой выпечки с использованием FOR/F цикл по линиям, SET/А, чтобы увеличить счетчик, и либо отсроченное расширение или вызов к подпрограмме вместе с утверждением IF чтобы добавить дополнительный текст в каждую третью строку.

Так вот вы получаете чистую пакетное чувство :-)

@echo off 
setlocal 
set "file=test.txt" 
set /a counter=0 

(for /f "delims=" %%i in ('^<%file% findstr /n "^"') do call:processline "%%~i")>%file%.new 
goto:eof 

:processline 
set "line=%~1" 
set /a check=counter%%3 
if %check% equ 0 if %counter% neq 0 echo(^</li^>^<li^> 
set /a counter+=1 
setlocal enabledelayedexpansion 
echo(!line:*:=! 
endlocal 
exit /b 

Edit: добавлена ​​findstr для пустых строк.

+1

+1, но вы забыли снять префикс номера строки из каждой строки после того, как вы добавили FINDSTR/N, чтобы сохранить пустые строки , Я исправил код. – dbenham

+1

Я добавил "tokens = 1 * delims =:" & "%% ~ j", но тем не менее ваш код лучше в случае ведущего ':'. Благодарю. – Endoro

+0

Хм, мне интересно, почему 'echo (! Line: *: =!' Не удаляет восклицательные знаки в '! Line!'! Nice. – Endoro

Смежные вопросы