Acciones sobre archivos de texto. [Batch]

Iniciado por leogtz, 24 Enero 2009, 00:30 AM

0 Miembros y 2 Visitantes están viendo este tema.

oloco


leogtz

#161
Bueno, a ver si he entendido, tu haces una consulta SQL la cual te devuelve los valores que comienzan con H y eso lo volcas a un archivo familia.txt...

Ahí hay que trabajar el archivo para que cada valor(ejemplo):

HEMILIO            
HRODRIGO
HCARMEN
HLORENA            

lo meta en una variable independiente, bueno, si he entendido bien, podríamos trabajar con un array:

@echo off
setlocal enabledelayedexpansion
set /a contador=0

rem "familia.txt" es el archivo conteniendo el resultado de la consulta:
rem szfamilyname
rem --------------------
rem HMAR
rem HTERESA
rem HLUZ

rem (3 rows affected)

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ familia.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!

rem Los valores son guardados en el array "query".
rem Para mostrar los valores del array:
rem Primera posición:
echo !query[0]!
rem Segunda posición:
echo !query[1]!
rem Tercera posición:
echo !query[2]!
rem Y así consecutivamente...
rem Solo estoy mostrando hasta el 3, claro que puede haber muchos más.
pause


He comentado un poco el código para que lo entiendas mejor, sino cualquier duda la aclaramos.

Tomando el archivo familia.txt con:

C:\Users\leo>type familia.txt
szfamilyname
--------------------
HEMILIO
HRODRIGO
HCARMEN
HLORENA

(4 rows affected)
C:\Users\leo>


El código devuelve:

C:\Users\leo>code.cmd
No. de valores: 4
HEMILIO
HRODRIGO
HCARMEN

C:\Users\leo>

Lo cual es correcto.

Ahora, si quisieramos mostrar todos los valores:

@echo off
setlocal enabledelayedexpansion
set /a contador=0

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ familia.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!

rem Los valores son guardados en el array "query".
rem Para mostrar los valores del array:
rem Primera posición:
echo !query[0]!
rem Segunda posición:
echo !query[1]!
rem Tercera posición:
echo !query[2]!
rem Y así consecutivamente...
echo.
echo Todos los valores son:
set /a contador-=1
for /l %%_ in (0,1,!contador!) do (
echo !query[%%_]!
)
pause


¿Me queda una duda, para qué utilizas Batch?, en el trabajo?, universidad?
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

oloco

#162
Hola de nuevo, Leo!
Verás, después de haber expuesto mi duda seguí investigando. He de decir que el ejemplo expuesto no es real. Con esto quiero decir que los datos obtenidos no son nombres de persona, sinó nombres de equipos (el ejemplo lo puse para tratar de hacerme entender mejor, pero pienso que fue un error).
El equipo con la base de datos al que se hace la consulta es un servidor, y los resultados obtenidos son los equipos que a él se conectan.
Una vez tenemos los datos, necesito hacer operaciones con ellos, como por ejemplo un ping, para obtener su IP y revisar que todos tengan conectividad y la misma máscara de subred... por ejemplo. Todo esto quisiera que se hiciese de forma automatizada, por ese motivo la importancia de tener una forma fácil de acceder a las variables.
Resumiendo: Mi script se conecta mediante psexec al servidor, hace la consulta sql y guarda los resultados a un fichero.
Ahora gracias a tu ayuda, puedo tener un contador que me indica cuantos resultados hay.
Sin embargo, sigo sin ver una forma de poder realizar operaciones con los equipos clientes, dado que su número es variable según el servidor al que se consulte.
Si siempre tuviese 2 clientes, en el script llamaría siempre a dos variables, con lo que se acaba el problema. Pero en mi caso, el script tiene que llamar a x variables:



Código (bash) [Seleccionar]
@echo off
setlocal enabledelayedexpansion
set /a contador=0

rem "familia.txt" es el archivo conteniendo el resultado de la consulta:
rem szfamilyname
rem --------------------
rem HMAR
rem HTERESA
rem HLUZ

rem (3 rows affected)

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ familia.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!

rem Los valores son guardados en el array "query".
rem Para mostrar los valores del array:
rem Primera posicion:
echo !query[0]!
rem Segunda posicion:
echo !query[1]!
rem Tercera posicion:
echo !query[2]!
rem Y así consecutivamente...
rem Solo estoy mostrando hasta el 3, claro que puede haber muchos mas.
pause

Aqui está mi problema. Si tuviese siempre tres resultados, pondría el código tal cual has expuesto, pero como los resultados pueden ser desde 1 hasta 12, no se muy bien como planteármelo para poder crear una orden de ping (entre otras) por cada uno de ellos.

Ante todo quiero agradecerte toda la ayuda que me estás brindando.
Espero puedas entender lo que intento explicarte, pues soy consciente de que esto no se me da demasiado bien y quizas estoy pasando cosas por alto.

Me mantengo a la espera.

Un abrazo!!

P.D Por cierto, respondiendo a tu pregunta. Este script lo utilizo para mi trabajo, y utilizo cmd pues los equipos a los que nos tenemos que conectar utilizan Windows XP o 2003, tienen unas directivas de seguridad elevadas y no tenemos permiso para utilizar utilidades de terceros.

leogtz

Al utilizar un array, tienes total control sobre todos los valores sabiendo el número de ellos, es decir, en mi último script:

@echo off
setlocal enabledelayedexpansion
set /a contador=0

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ familia.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!

rem Los valores son guardados en el array "query".
rem Para mostrar los valores del array:
rem Primera posición:
echo !query[0]!
rem Segunda posición:
echo !query[1]!
rem Tercera posición:
echo !query[2]!
rem Y así consecutivamente...
echo.
echo Todos los valores son:
set /a contador-=1
for /l %%_ in (0,1,!contador!) do (
echo !query[%%_]!
)
pause


Suponiendo que los valores fueran máquinas y yo quisiera saber cuales de ellas están online u offline:

@echo off
setlocal enabledelayedexpansion
set /a contador=0

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ familia.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!
echo Todos los valores son:
set /a contador-=1
for /l %%_ in (0,1,!contador!) do (
ping -n 4 !query[%%_]! > nul 2>&1 && (
echo Máquina !query[%%_]! - online
) || (
echo Máquina !query[%%_]! - offline
)
)
pause


!query! es el array, si yo quiero acceder a la posición x:
!query[x]!

Saludos, cualquier duda nos dices.
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

oloco

Hola Leo.
Pienso que más o menos me va quedando algo más claro. Lo cierto es que me resulta bastante complejo, pero con ganas de aprender (además en mi trabajo me resultará muy util).
He ejecutado el código que has creado, y funciona correctamente menos en un punto. En este equipo tengo sólo dos clientes (debería reportar dos equipos asociados a este servidor), pero cuando ejecuto la parte del código que realiza el ping a cada uno de los valores del array, tambien lo realiza a un "equipo" cuyo valor es nulo.

Código (bash) [Seleccionar]

Maquina H111            - online
Maquina H112            - offline
Maquina  - offline
Press any key to continue . . .


Me doy cuenta de que ese tercer valor es el que corresponde con !contador! dentro del código.
¿Alguna sugerencia?
Gracias!

leogtz

¿Puedo ver la tabla o el archivo de texto que usas cuando da error?
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

oloco

Por supuesto. Este es el fichero temp.txt (en el que se graban los equipos):

szcomputername     
--------------------
H111
H112         

(2 rows affected)


y esto es el código que tengo en el script:
Código (bash) [Seleccionar]

@echo off
setlocal enabledelayedexpansion
set /a contador=0

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ temp.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!



echo REVISION DE LA SUBRED EN EL CONJUNTO DE CAJAS


for /l %%_ in (0,1,!contador!) do (
ping -n 1 !query[%%_]! > nul 2>&1 && (
echo Maquina !query[%%_]! - online
) || (
echo Maquina !query[%%_]! - offline
)
)
pause


leogtz

Sí, el problema está con la variable contador, que da un valor de más, solo hay que decrementarla y listo.

@echo off
setlocal enabledelayedexpansion
set /a contador=0

for /f "tokens=*" %%_ in ('findstr /r ^H.*$ temp.txt') do (
set query[!contador!]=%%_
set /a contador+=1
)
echo No. de valores: !contador!
echo REVISION DE LA SUBRED EN EL CONJUNTO DE CAJAS
rem Decrementamos la variable en una unidad.
set /a contador-=1
for /l %%_ in (0,1,!contador!) do (
ping -n 1 !query[%%_]! > nul 2>&1 && (
echo Maquina !query[%%_]! - online
) || (
echo Maquina !query[%%_]! - offline
)
)
pause
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com

oloco

Efectivamente Leo. Ya funciona todo correctamente.
Ahora, a partir de aquí, ya puedo seguir aumentando funciones al script para darle más funcionalidad, así que no sería extraño que vuelva a pasarme por aquí en busca de tu consejo.
Te agradezco enormemente la paciencia y tiempo gastados conmigo.

P.D Por cierto, podrías recomendarme alguna lectura, algún libro o manual para poder aprender nuevos conocimientos sobre batch?

Un saludo, y gracias por todo!!!

leogtz

ss64.com contiene ayuda sobre los comandos de Windows XP y algunos ejemplos.
robvanderwoude.com
http://www.robvanderwoude.com/batchstart.php también contiene mucha ayuda.
Y por supuesto este sitio, los temas pegados en esta sección.

Saludos.
Código (perl) [Seleccionar]

(( 1 / 0 )) &> /dev/null || {
echo -e "stderrrrrrrrrrrrrrrrrrr";
}

http://leonardogtzr.wordpress.com/
leogutierrezramirez@gmail.com