Consulta Batch encuentra archivo XML por contenido y modifica linea

Iniciado por chepem2, 31 Enero 2014, 17:18 PM

0 Miembros y 1 Visitante están viendo este tema.

chepem2

Hola a todos!

Bien pues tengo esta pequeña interrogante: Estoy interesado en hacer un batch que me busque un archivo xml en la carpeta donde se guardan los archivos de confirguracion de las WIFI en win 7, la idea basicamente es poder encontrar el archivo no por el nombre del mismo, sino porque en una determinada linea del codigo que contiene se encuentra el nombre de la red (linea 7), a continuacion despues de encontrarlo necesito cambiar el contenido de la linea donde se encuentra la contraseña cifrada (linea 22), para esto estoy probando codigo que encontré en otro thread del foro:

@echo off
(
echo 22
echo <keyMaterial>Hola</keyMaterial>
echo w
echo e
) | edlin /b {B379EDC0-8C8F-457A-8125-86D1FAA1A03F}.xml


donde {B379EDC0-8C8F-457A-8125-86D1FAA1A03F}.xml es el nombre del archivo, claro esto es solo de prueba puesto que la intencion es que no lo encuentre por nombre sino por lo que contiene la linea 7 del mismo.

Deseo realizarlo de esta manera ya que la finalidad de este batch es la de modificar las contraseñas de las computadoras de una pequeña empresa, donde sino se hace de esta manera tendría que modficarse una por una todas las computadoras.

saludos y les agradezco de antemano.

Eleкtro

#1
Hola

Si estás seguro de que el número de lineas y el contenido nunca va a cambiar en ese archivo XML pues... entonces la solución que has pensado es viable, aunque no me parece la mejor solución, yo te recomendaría utilizar la aplicación XMLStarlet que sirve precísamente para la edición de archivos XML, aunque óbviamente deberás tratar el archivo como un archivo XML indicando el namespace el attributo a modificar y etc.

Por otro lado Batch es muy feo y lento, muy poco óptimo para estas tareas de procesamiento, te propongo una solución mejor utilizando VBS (El intérprete ya viene con Windows así que no tienes que instalar software en la empresa):

NOTA: Asegúrate de que la codificación de los archivos XML sea ANSI.

Código (vb) [Seleccionar]
' El Objeto 'FileSystemObject'.
Set FSO        = CreateObject("Scripting.FileSystemObject")

Directory      = ".\"             ' El directorio donde guardas los archivos.
FileExt        = "xml"            ' La extensión de los archivos a escanear.
LineToScan     = 7                ' La linea para identificar el archivo.
TextToMatch    = "Something"      ' El texto que buscar en la linea a examinar.
LineToReplace  = 22               ' El número de la linea a reemplazar.
TextToReplace  = "<New Password>" ' El nuevo texto de la linea a reemplazar.

' Recorro los archivos del directorio 'Directory'.
For Each File In FSO.GetFolder(Directory).Files

' Si la extensión del archivo es igual que 'FileExt'...
If LCase(FSO.GetExtensionName(File)) = LCase(FileExt) Then

' Creo un Array con el contenido del archivo (las lineas de texto).
Lines = Split(FSO.OpenTextFile(File, 1).ReadAll(), vbcrlf)

' Si la cantidad de elementos del Array (lineas) es igual o mayor que 'LineToReplace';
' y si además el texto de la linea 'LineToScan' es igual a 'TextToMatch'...
If (uBound(Lines) => (LineToReplace -1)) And _
  (LCase(Lines(LineToScan - 1)) = LCase(TextToMatch)) Then

' Reemplazo la linea 'LineToReplace' por el texto 'TextToReplace'.
Lines(LineToReplace -1) = TextToReplace

' Reemplazo el archivo original, con los cambios realizados.
FSO.CreateTextFile(File, 2).Write(Join(Lines, vbcrlf))

'' ...O Creo un nuevo documento en la misma carpeta del archivo original, con los cambios realizados.
' FSO.CreateTextFile(FSO.GetBaseName(File) & ".tmp", 2).Write(Join(Lines, vbcrlf))

' Detengo la iteración de los elementos, salgo del búcle.
Exit For ' // Each File In FSO.GetFolder(Directory).Files

End If ' // (uBound(Lines) => (LineToReplace -1)) And (LCase(Lines(LineToScan - 1)) = LCase(TextToMatch))

End If ' // LCase(FSO.GetExtensionName(File)) = LCase(FileExt)

Next ' // File

Wscript.Quit(0) ' Salisa exitosa: '0'


Modifícalo a tus necesidades,
Saludos!