Problema con fecha en programa . bat...

Iniciado por jconnor, 29 Abril 2009, 19:24 PM

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

jconnor

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 (dos) [Seleccionar]
@ECHO OFF
CLS
ECHO.
ECHO     COPIA DE SEGURIDAD DE DATOS
ECHO.

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

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%

wzzip -P -r D:\LZHWEB\%nombre%.zip D:\bogota\bd\jord\*.*

ECHO.

set nombre=SER%mes%%dia%

wzzip -P -r D:\LZHWEB\%nombre%.zip D:\servicio\bd\jord\*.*


ECHO.
ECHO  PROCESO TERMINADO :
TIME


y el de restaurarlo:

Código (dos) [Seleccionar]
@ECHO OFF
CLS
ECHO.
ECHO     COPIA DE SEGURIDAD DE DATOS
ECHO.

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

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

set cont=1

set /a dia=%dia%-%cont%


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 por la ayuda...

jconnor

#1
Ayuda por favor, el viernes voy a tener el problema q describo, alguna idea? :-(

Novlucker

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
Contribuye con la limpieza del foro, reporta los "casos perdidos" a un MOD XD

"Hay dos cosas infinitas: el Universo y la estupidez  humana. Y de la primera no estoy muy seguro."
Albert Einstein

jconnor

Cita de: 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

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  ::)

EddyW

Cita de: jconnor en  5 Mayo 2009, 00:03 AM
Cita de: 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

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
Para cuando aprendas, usa Time en VBS para hacer eso..
SaluDOS!!!

jconnor

Cita de: 3D1 en  5 Mayo 2009, 03:53 AM
Cita de: jconnor en  5 Mayo 2009, 00:03 AM
Cita de: 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

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
Para cuando aprendas, usa Time en VBS para hacer eso..
SaluDOS!!!

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

Novlucker

#6
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 (vb) [Seleccionar]
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 (dos) [Seleccionar]
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
Contribuye con la limpieza del foro, reporta los "casos perdidos" a un MOD XD

"Hay dos cosas infinitas: el Universo y la estupidez  humana. Y de la primera no estoy muy seguro."
Albert Einstein

jconnor

Cita de: 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 (vb) [Seleccionar]
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 (dos) [Seleccionar]
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.


Novlucker

Contribuye con la limpieza del foro, reporta los "casos perdidos" a un MOD XD

"Hay dos cosas infinitas: el Universo y la estupidez  humana. Y de la primera no estoy muy seguro."
Albert Einstein

jconnor

Cita de: 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

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 ;-)