Имя пользователя:
Пароль:
 | Правила  

Компьютерный форум OSzone.net » Программирование, базы данных и автоматизация действий » Скриптовые языки администрирования Windows » CMD/BAT - [решено] поиск по xml

Ответить
Настройки темы
CMD/BAT - [решено] поиск по xml

Пользователь


Сообщения: 102
Благодарности: 8

Профиль | Отправить PM | Цитировать


Изменения
Автор: firstarey
Дата: 06-03-2014
суть:
есть xml файлы, надо вытащить информацию из определенного тега

как делаю:

Код: Выделить весь код
set File_name=file.xml
rem как бы имя проще получать ? так чтоб перетаскиваешь xml на
rem батник и батник в итоге получает имя xml файла
rem это что то типа:
rem set File_name=%1

findstr "<CadastralNumber>" %File_name% >1.txt
rem находим по тегу кадастровый номер

For /F "tokens=1,2* Delims=<CadastralNumber>" %%a In (1.txt) Do (echo %%a >>KADNumber.txt)
rem обрезаем тег <CadastralNumber>

Вопрос:
как оставить только 1 строку ? т.к. последние 2 явно подрезаны и не актуальны

For /F "tokens=1,2,3,4* Delims=:" %%a In (KADNumber.txt) Do (
echo K_Region = %%a	регион >>out.txt
echo K_Raion = %%b	район >>out.txt
echo K_kvartal = %%c	квартал >>out.txt
if %%d NEQ "" (echo K_uchastok = %%d	участок >>out.txt) 
)
rem приводим к удобному виду
Проблема указана в вопросе, собсно надо как то оставить лишь первый результат или удалить остальные строки, кроме первой
Возможно предложите более элегантное решение

Отправлено: 09:14, 01-04-2013

 

Пользователь


Сообщения: 102
Благодарности: 8

Профиль | Отправить PM | Цитировать


Цитата Diskretor:
приложенный Вами код не работает вообще »
виноват, поторопился, дважды For указал
Цитата Diskretor:
Так? »
да, goto в данном случае спасает от поиска всех результатов и получается только первый найденный.

благодарю за наводку

Отправлено: 06:27, 02-04-2013 | #11



Для отключения данного рекламного блока вам необходимо зарегистрироваться или войти с учетной записью социальной сети.

Если же вы забыли свой пароль на форуме, то воспользуйтесь данной ссылкой для восстановления пароля.


Пользователь


Сообщения: 102
Благодарности: 8

Профиль | Отправить PM | Цитировать


суть:
последний кусок кода, комментарием выделена строка (83)
переменная не желает принимать значение которое ей хочу присвоить (видно по выводу echo)

при этом отдельно данный кусок кода прекрасно себя чувствует.
подозрения падают на %K_ucastok% что тут может быть не так ? голову сломал

сам скрипт целиком:
читать дальше »
Код: Выделить весь код
@echo off
Color 0e

rem задаем переменные:
set File_name=file.xml
:: как бы имя проще получать ? так чтоб перетаскиваешь xml на
:: батник и батник в итоге получает имя xml файла
:: это что то типа:
:: set File_name=%1
set base_region=region.txt
set base_rayion=rayion.txt
set KPT=0

rem находим по тегу кадастровый номер:
For /F "tokens=2-5 Delims=<>:" %%a In ('find "<CadastralNumber>" ^<"%File_name%"') Do (
	set K_Region=%%a
	set K_Rayion=%%b
	set K_kvartal=%%c
	if %%d=="" (set KPT=1) else set K_uchastok=%%d
	goto :_ext1
)
:_ext1
rem выводим результат на экран:
if %KPT%==0 (
	echo ®, ¤*, нв® ‚›Џ€‘ЉЂ!!
	echo ====================
	echo %K_Region%:%K_Rayion%:%K_kvartal%:%K_uchastok%
	echo ====================
	echo.
)
if %KPT%==1 (
	echo ®, ¤*, нв® ЉЏ’!!
	echo ================
	echo %K_Region%:%K_Rayion%:%K_kvartal%
	echo ================
	echo.
)

rem находим название региона по номеру:
for /f "delims=] tokens=1*" %%a in ('find /n "%K_Region%" %base_region%') do (set T_Region=%%b)
set region=%T_Region:~4,50%
rem выводим результат на экран:
echo %T_Region:~1,50%

rem находим название района по номеру:
rem проверка на условный кад район
if %K_Rayion%==00 (
	set rayion=“б«®ў*л© Є*¤*бва®ўл© а*©®*
	echo 00=“б«®ў*л© Є*¤*бва®ўл© а*©®*
	goto :_ext2
)
for /f "delims=] tokens=1*" %%a in ('find /n "%K_Rayion%" %K_Region%_%base_rayion%') do (set T_Rayion=%%b)
set rayion=%T_Rayion:~4,50%
rem выводим результат на экран:
echo %T_Rayion:~1,50%
:_ext2

rem проверяем существует ли каталог:
rem %~p0
if NOT exist "%K_Region%_%region%\%K_Region%_%K_Rayion%_%rayion%\%K_Region%_%K_Rayion%_%K_kvartal%\" MD "%K_Region%_%region%\%K_Region%_%K_Rayion%_%rayion%\%K_Region%_%K_Rayion%_%K_kvartal%\"

rem подсчет количества символов в обозначении участка:
call :var_Count "%K_uchastok%" K_uchastok_zero
if %K_uchastok_zero%==1 set K_uchastok=000%K_uchastok%
if %K_uchastok_zero%==2 set K_uchastok=00%K_uchastok%
if %K_uchastok_zero%==3 set K_uchastok=0%K_uchastok%
goto :_ext3
 
:var_count
set var=%~1
if not defined var exit /b
set var=%var:~1%
set /a %2+=1
call :var_count "%var%" %2
exit /b

:_ext3
rem переименовываем файл:
if %KPT%==0 (
	set new_file_name=Љ‚‡“_%K_uchastok%_%date:~6,4%-%date:~3,2%-%date:~0,2%.xml
	echo Ќ®ў®Ґ Ё¬п д*©«*:=Љ‚‡“_%K_uchastok%_%date:~6,4%-%date:~3,2%-%date:~0,2%.xml
	echo Ќ®ў®Ґ Ё¬п д*©«*:=%new_file_name%
	rem именно тут каккая то проблема ^^
	rem т.е. в переменную не уходит значение
	echo %~p0%file_name%
	echo %~p0%new_file_name%
	ren %file_name% %new_file_name%
	pause
	move %new_file_name% "%K_Region%_%region%\%K_Region%_%K_Rayion%_%rayion%\%K_Region%_%K_Rayion%_%K_kvartal%\"
	echo Ќ®ў*п Ї*ЇЄ* д*©«*:="%K_Region%_%region%\%K_Region%_%K_Rayion%_%rayion%\%K_Region%_%K_Rayion%_%K_kvartal%\"
)
pause



отдельно проблемный кусок, работает без проблем:
читать дальше »
Код: Выделить весь код
@echo off
set File_name=file.xml
set K_uchastok=0038
set new_file_name=Љ‚‡“_%K_uchastok%_%date:~6,4%-%date:~3,2%-%date:~0,2%.xml
echo Ќ®ў®Ґ Ё¬п д*©«*:=Љ‚‡“_%K_uchastok%_%date:~6,4%-%date:~3,2%-%date:~0,2%.xml
echo Ќ®ў®Ґ Ё¬п д*©«*:=%new_file_name%
echo %~p0%file_name%
echo %~p0%new_file_name%
ren %file_name% %new_file_name%
pause


весь набор прилагаю во вложении

Последний раз редактировалось firstarey, 06-03-2014 в 07:23.


Отправлено: 14:06, 02-04-2013 | #12


Пользователь


Сообщения: 148
Благодарности: 39

Профиль | Сайт | Отправить PM | Цитировать


Новое значение, присвоенное переменной под скобками, циклом или конкатенацией команд (&), можно получить из нее, не выходя из этой же конструкции, раскрывая только через восклицательные знаки:
Код: Выделить весь код
set new_file_name=value
(
  set new_file_name=new value
  echo %new_file_name%
  echo !new_file_name!
)
Это называется режим отложенного расширения переменных среды, который необходимо предварительно включить, расположив в начале пакетного файла директиву:
Код: Выделить весь код
Setlocal EnableDelayedExpansion
либо запуская бат-файл следующим способом:
Код: Выделить весь код
cmd /v:on /c batnik.bat
P.S. Чтобы не использовать несколько кодировок (обе Win-1251 и DOS OEM-866) в пакетном файле, достаточно сохранить файл любым вменяемым редактором (например, AkelPad) в кодировке DOS.

-------
Alex Dragokas

Это сообщение посчитали полезным следующие участники:

Отправлено: 16:53, 02-04-2013 | #13


Пользователь


Сообщения: 102
Благодарности: 8

Профиль | Отправить PM | Цитировать


Очередная заминка:

не все *.XML файлы отформатированы с переносом строки, т.е. попадаются файлы где нет переноса на след строку после закрытия тега, например фрагмент:
Код: Выделить весь код
<Location><Code_OKATO>57401380000</Code_OKATO></Location><Parcels><Parcel CadastralNumber="59:01:4410923:25" Name="01" State="01" DateCreated="2006-09-13"><Areas><Area><AreaCode>009</AreaCode>
т.е. весь файл в одну строку.
соответственно
Цитата firstarey:
сам скрипт целиком: »
уже не может обработать файл..

через Notepad++ делается просто, но хочется автоматизировать процесс.

сейчас поиск номера (59:01:4410923:25) выполняется следующим образом:
читать дальше »
Код: Выделить весь код
set File_name=file.xml
:: как бы имя проще получать ? так чтоб перетаскиваешь xml на
:: батник и батник в итоге получает имя xml файла
:: это что то типа:
:: set File_name=%1
set KPT=0

For /F "tokens=2-5 Delims=: " %%a In ('find "<Parcel CadastralNumber=" ^<"%File_name%"') Do (
	set K_Region=%%a
	set K_Rayion=%%b
	set K_kvartal=%%c
	if %%d=="" (set KPT=1) else set K_uchastok=%%d
	goto :_ext1
)
:_ext1

set K_Region=%K_Region:~17,2%
set K_uchastok=%K_uchastok:~0,-1%
echo %K_Region%:%K_Rayion%:%K_kvartal%:%K_uchastok%
pause


Возможно ли как то через cmd реализовать замену "><" на ">перенос строки<" (>/n< в Notepad++)?
Ну или другой вариант? возможно изменить алгоритм поиска ?

второй вопрос:
как бы имя обрабатываемого файла проще получать ? так чтоб перетаскиваешь xml на
батник и батник в итоге получает имя xml файла в переменную

Отправлено: 11:24, 04-04-2013 | #14


Ветеран


Сообщения: 27449
Благодарности: 8088

Профиль | Отправить PM | Цитировать


Цитата firstarey:
второй вопрос:
как бы имя обрабатываемого файла проще получать ? так чтоб перетаскиваешь xml на
батник и батник в итоге получает имя xml файла в переменную »
Код: Выделить весь код
@echo off
setlocal enableextensions enabledelayedexpansion

set sFile=%~1

if defined sFile (
	if exist "%sFile%" (
		rem Здесь Ваш код
	) else (
		echo File [%sFile%] not found
	)
) else (
	echo Usage: %~0 ^<path to xml file^>
)

endlocal
exit /b 0

Отправлено: 17:11, 04-04-2013 | #15



Компьютерный форум OSzone.net » Программирование, базы данных и автоматизация действий » Скриптовые языки администрирования Windows » CMD/BAT - [решено] поиск по xml

Участник сейчас на форуме Участник сейчас на форуме Участник вне форума Участник вне форума Автор темы Автор темы Шапка темы Сообщение прикреплено

Похожие темы
Название темы Автор Информация о форуме Ответов Последнее сообщение
CMD/BAT - [решено] Поиск и замена фразы <signature> на sign в xml или txt dark-------13 Скриптовые языки администрирования Windows 2 18-03-2013 11:21
[решено] Поиск <строки> в XML semiono AutoIt 28 17-11-2010 19:53
[решено] проверка XML-файла на соответствие XML schema в IE 6 и Firefox 2 dimait Вебмастеру 4 23-08-2007 02:02
Поиск в яндекс.xml (выделено из "Зацените сайт!") Vampire Вебмастеру 21 11-09-2006 20:31
Решено | XML. DOM. Поиск дочерних элементов. penykov Программирование и базы данных 3 27-04-2006 15:46




 
Переход