Foro de elhacker.net

Programación => Scripting => Mensaje iniciado por: jconnor en 29 Abril 2009, 19:24 pm



Título: Problema con fecha en programa . bat...
Publicado por: jconnor en 29 Abril 2009, 19:24 pm
Hola amigos, primero q todo saludarlos y felicitarlos pr el foro, se encuentran buenas cosas;
buscando y guiandome en el foro cree un programa para realizar un backup de una base de datos y ponerle como nombre la fecha en q se hace, en escencia lo q hace es comprimirlo con winzip y copiarlo a una ubicacion; el problema surge cuando necesito restaurar dicha base en una de prueba, todos los dias, creé el programa para restaurarla, entonces lo q hago es con el mismo codigo q le doy el nombre, identifico el backup creado y le resto 1 al dia, puesto q hago el backup a las 11pm todos los dias y lorestauro a la 1 am del siguiente dia, hasta ahi todo bien, el problema surge cuando la fecha es el primero del mes, puesto q como siempre le resto 1 al dia y cuando pongo el nombre en la parte del dia me queda 0!, cuando el primero cae en lunes, peor, porque le resto 3 y me da -2, no se q hacer, se q existe la variable date pero no se como restarle 1 para q me de la fecha anterior, espero q por favor me ayuden, aca esta el codigo de crear el backup:

Código
  1. @ECHO OFF
  2. CLS
  3. ECHO     COPIA DE SEGURIDAD DE DATOS
  4.  
  5. set dia=
  6. set mes=
  7. set año=
  8. set nombre=
  9.  
  10. for /f "tokens=1-3 delims=/ " %%a in ('date /t') do (set dia=%%a& set mes=%%b& set año=%%c)
  11.  
  12. set nombre=BOG%mes%%dia%
  13.  
  14. wzzip -P -r D:\LZHWEB\%nombre%.zip D:\bogota\bd\jord\*.*
  15.  
  16.  
  17. set nombre=SER%mes%%dia%
  18.  
  19. wzzip -P -r D:\LZHWEB\%nombre%.zip D:\servicio\bd\jord\*.*
  20.  
  21.  
  22. ECHO  PROCESO TERMINADO :
  23. TIME

y el de restaurarlo:

Código
  1. @ECHO OFF
  2. CLS
  3. ECHO     COPIA DE SEGURIDAD DE DATOS
  4.  
  5. set dia=
  6. set mes=
  7. set año=
  8. set nombre=
  9. set cont=
  10.  
  11. for /f "tokens=1-3 delims=/ " %%a in ('date /t') do (set dia=%%a& set mes=%%b& set año=%%c)
  12.  
  13. set cont=1
  14.  
  15. set /a dia=%dia%-%cont%
  16.  
  17.  
  18. set nombre=BOG%mes%%dia%
  19.  
  20. cd \
  21.  
  22. d:
  23.  
  24. cd \
  25.  
  26. cd copiabog\bd\jord
  27.  
  28. del j*.d*
  29.  
  30. wzunzip -e -o C:\LZHWEB\%nombre%.zip d:\copiabog\bd\jord
  31.  
  32.  
  33. set nombre=SER%mes%%dia%
  34.  
  35. cd \
  36.  
  37. cd copiaserv\bd\jord
  38.  
  39. del j*.d*
  40.  
  41. wzunzip -e -o C:\LZHWEB\%nombre%.zip d:\copiaserv\bd\jord
  42.  
  43. ECHO  PROCESO TERMINADO :
  44. TIME
  45.  
Gracias por la ayuda...


Título: Re: Problema con fecha en programa . bat...
Publicado por: jconnor en 29 Abril 2009, 23:16 pm
Ayuda por favor, el viernes voy a tener el problema q describo, alguna idea? :-(


Título: Re: Problema con fecha en programa . bat...
Publicado por: Novlucker en 2 Mayo 2009, 06:30 am
El problema que veo es determinar si el mes tiene 30 o 31 días (28/29 febrero), sería realmente sencillo hacerlo en vbs, pero en batch  :-\

Saludos


Título: Re: Problema con fecha en programa . bat...
Publicado por: jconnor en 5 Mayo 2009, 00:03 am
El problema que veo es determinar si el mes tiene 30 o 31 días (28/29 febrero), sería realmente sencillo hacerlo en vbs, pero en batch  :-\

Saludos

Ok, amigo, gracias, yo de vbs nada, sera q me puedes orientar como combino el script con vbs, donde puedo encontrar informacion para guiarme?, gracias por la ayuda  ::)


Título: Re: Problema con fecha en programa . bat...
Publicado por: EddyW en 5 Mayo 2009, 03:53 am
El problema que veo es determinar si el mes tiene 30 o 31 días (28/29 febrero), sería realmente sencillo hacerlo en vbs, pero en batch  :-\

Saludos

Ok, amigo, gracias, yo de vbs nada, sera q me puedes orientar como combino el script con vbs, donde puedo encontrar informacion para guiarme?, gracias por la ayuda  ::)
Aqui mismo en el foro hay un tuto colgado y es el de NovLucker:
http://foro.elhacker.net/scripting/tutorial_vbscript-t229032.0.html (http://foro.elhacker.net/scripting/tutorial_vbscript-t229032.0.html)
Para cuando aprendas, usa Time en VBS para hacer eso..
SaluDOS!!!


Título: Re: Problema con fecha en programa . bat...
Publicado por: jconnor en 5 Mayo 2009, 23:41 pm
El problema que veo es determinar si el mes tiene 30 o 31 días (28/29 febrero), sería realmente sencillo hacerlo en vbs, pero en batch  :-\

Saludos

Ok, amigo, gracias, yo de vbs nada, sera q me puedes orientar como combino el script con vbs, donde puedo encontrar informacion para guiarme?, gracias por la ayuda  ::)
Aqui mismo en el foro hay un tuto colgado y es el de NovLucker:
http://foro.elhacker.net/scripting/tutorial_vbscript-t229032.0.html (http://foro.elhacker.net/scripting/tutorial_vbscript-t229032.0.html)
Para cuando aprendas, usa Time en VBS para hacer eso..
SaluDOS!!!

Ok amigo, me pondre a revisar el tuto, gracias por la ayuda


Título: Re: Problema con fecha en programa . bat...
Publicado por: Novlucker en 6 Mayo 2009, 07:07 am
Ahora que lo miro detenidamente me doy cuenta de lo sencillo que es  :-X

No es necesario que aprendas vbs, te dejo el code:
Código
  1. wscript.echo dateadd("d",-1,wscript.arguments(0))

Solamente eso, este script recibe una fecha como parámetro, y le resta un día, para posteriormente mostrarlo en pantalla
Lo que deberías de hacer es dejar el script (*.vbs) en el mismo directorio donde esta el bat (para mayor comodida) o bien llamarlo con la ruta completa agregando una línea más o menos así (en tu bat)

Código
  1. cscript/nologo fecha.vbs %date% > fecha.txt

Como ves, simplemente lo llamas desde línea de comandos, le pasas una fecha como parámetro, en este caso la de hoy, y el script mostrará en pantalla la fecha -1 día

En tu caso puntualmente deberías de redirigir la salida a un archivo temporal (ej: fecha.txt) como he hecho en el ejemplo, ya que de este modo tendrás la fecha en un archivo al que puedes consultar luego desde tu batch.

Es decir, con esto almacenas la fecha en un archivo, y luego tu te encargas de acceder a el desde el batch y hacer lo que gustes con el contenido  ;)

Espero se haya entendido ...

Saludos


P.D: igualmente y trás ver este ejemplo (siempre y cuando se haya entendido) espero te entren ganas de aprender algo de vbs, ya que como ves con un par de líneas puedes encontrar la solución a un problema


Título: Re: Problema con fecha en programa . bat...
Publicado por: jconnor en 8 Mayo 2009, 00:29 am
Ahora que lo miro detenidamente me doy cuenta de lo sencillo que es  :-X

No es necesario que aprendas vbs, te dejo el code:
Código
  1. wscript.echo dateadd("d",-1,wscript.arguments(0))

Solamente eso, este script recibe una fecha como parámetro, y le resta un día, para posteriormente mostrarlo en pantalla
Lo que deberías de hacer es dejar el script (*.vbs) en el mismo directorio donde esta el bat (para mayor comodida) o bien llamarlo con la ruta completa agregando una línea más o menos así (en tu bat)

Código
  1. cscript/nologo fecha.vbs %date% > fecha.txt

Como ves, simplemente lo llamas desde línea de comandos, le pasas una fecha como parámetro, en este caso la de hoy, y el script mostrará en pantalla la fecha -1 día

En tu caso puntualmente deberías de redirigir la salida a un archivo temporal (ej: fecha.txt) como he hecho en el ejemplo, ya que de este modo tendrás la fecha en un archivo al que puedes consultar luego desde tu batch.

Es decir, con esto almacenas la fecha en un archivo, y luego tu te encargas de acceder a el desde el batch y hacer lo que gustes con el contenido  ;)

Espero se haya entendido ...

Saludos


P.D: igualmente y trás ver este ejemplo (siempre y cuando se haya entendido) espero te entren ganas de aprender algo de vbs, ya que como ves con un par de líneas puedes encontrar la solución a un problema


Hola Novlucker, primero que todo agradecerte por tu tiempo;  he probado tu código y funciona perfecto en el txt queda la fecha del dia anterior, pero no se como llamar esa fecha desde mi batch y utilizarlo en una variable: yo utilizo

for /f "tokens=1-3 delims=/ " %%a in ('date /t') do (set dia=%%a& set mes=%%b& set año=%%c)

set nombre=BOG%mes%%dia%

para darle el nombre a mi archivo, pero no se como asignarle el mes y dia del txt a las variables, nuevamente gracias por la ayuda.



Título: Re: Problema con fecha en programa . bat...
Publicado por: Novlucker en 8 Mayo 2009, 15:58 pm
Tu respuesta  ;)

https://foro.elhacker.net/scripting/batch_leer_lineas_de_archivo_y_generar_opciones-t249926.0.html;msg1205401#msg1205401

Saludos


Título: Re: Problema con fecha en programa . bat...
Publicado por: jconnor en 9 Mayo 2009, 01:12 am
Tu respuesta  ;)

https://foro.elhacker.net/scripting/batch_leer_lineas_de_archivo_y_generar_opciones-t249926.0.html;msg1205401#msg1205401

Saludos

Hola Novlucker, nuevamente gracias por tu tiempo y por la ayuda, esa era la respuesta, me guié con el post de Leo Gutierrez (gracias a el tambien), pero tenia problemas con la sintaxis del for, no entendia bien el /f o /l , buscando me encontre ésta página: http://www.robvanderwoude.com/ntfor.php y ahi ya todo claro, asi ha quedado mi script:

@ECHO OFF
CLS
ECHO.
ECHO     COPIA DE SEGURIDAD DE DATOS
ECHO.

set dia=
set mes=
set año=
set nombre=
set cont=

ECHO.

cscript/nologo fechaS.vbs %date% > fecha.txt

ECHO.


for /f "tokens=1-3 delims=/" %%a in (fecha.txt) do (set dia=%%a& set mes=%%b& set año=%%c)

set nombre=BOG%mes%%dia%

cd \

d:

cd \

cd copiabog\bd\jord

del j*.d*

wzunzip -e -o C:\LZHWEB\%nombre%.zip d:\copiabog\bd\jord

ECHO.

set nombre=SER%mes%%dia%

cd \

cd copiaserv\bd\jord

del j*.d*

wzunzip -e -o C:\LZHWEB\%nombre%.zip d:\copiaserv\bd\jord

ECHO.
ECHO  PROCESO TERMINADO :
TIME

Gracias nuevamente ;-)


Título: Problema con fecha en programa . bat...
Publicado por: yelopez en 2 Junio 2011, 20:52 pm
Buenas tardes!!
tengo el mismo problema que tenia jconnor así que me tome el atrevimiento de  probar el script que dejo.. Ahora bien no me funciona porq no me quedo muy claro lo del archivo de vbs y el txt, los cree en el escritorio al igual que mi .bat pero nada  >:( no estoy clara sobre las variable que declaraste.. a todas estas mi petición es: podrías por favor explicar los pasos que seguiste en la creación de tu .bat??
el que en un principio cree es

rem Establecemos el juego de caracteres ISO-8859-1 (Latin 1)
chcp 28591 > NUL
rem variables que se usan
set FECHA_ACTUAL=%DATE%
set ANO=%FECHA_ACTUAL:~6,4%
set MES=%FECHA_ACTUAL:~3,2%
set DIA=%FECHA_ACTUAL:~0,2%
set va=1
set /a ANT=%DIA%-%va%
rem comando para conectarse al servidor remoto, permite loguearse automaticamente
NET USE z: \\servidor al que me conecto\nombre del servidor /dominio\usuario clave
rem comando para copiar archivo desde un servidor al disco local
xcopy \\servidor al que me conecto\carpeta1\carpeta2\carpeta3\AHB%ANO%%MES%%ANT%.mdb  C:\donde voy a copiar el archivo
rem comando para renombrar el archivo
ren C:\donde copie el archivo\AHB%ANO%%MES%%ANT%.mdb nombre_nuevo.mdb
endlocal
echo.
pause
Mi problema es la fecha cuando es 01 de cada messs y necesito tomar el del día anterior

De antemano gracias por la ayuda, espero haberme explicado!