Autor
|
Tema: Problema con fecha en programa . bat... (Leído 11,138 veces)
|
jconnor
Desconectado
Mensajes: 6
|
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: CLS ECHO COPIA DE SEGURIDAD DE DATOS for /f "tokens=1-3 delims=/ " %%a in ('date /t' ) do (set dia= %%a& set mes= %%b& set año= %%c) wzzip -P -r D:\LZHWEB\%nombre%.zip D:\bogota\bd\jord\*.* wzzip -P -r D:\LZHWEB\%nombre%.zip D:\servicio\bd\jord\*.* TIME
y el de restaurarlo:CLS ECHO COPIA DE SEGURIDAD DE DATOS for /f "tokens=1-3 delims=/ " %%a in ('date /t' ) do (set dia= %%a& set mes= %%b& set año= %%c) d: wzunzip -e -o C:\LZHWEB\%nombre%.zip d:\copiabog\bd\jord wzunzip -e -o C:\LZHWEB\%nombre%.zip d:\copiaserv\bd\jord TIME
Gracias por la ayuda...
|
|
« Última modificación: 2 Junio 2011, 22:12 pm por Leo Gutiérrez. »
|
En línea
|
|
|
|
jconnor
Desconectado
Mensajes: 6
|
Ayuda por favor, el viernes voy a tener el problema q describo, alguna idea?
|
|
« Última modificación: 2 Mayo 2009, 06:28 am por Novlucker »
|
En línea
|
|
|
|
Novlucker
Ninja y
Colaborador
Desconectado
Mensajes: 10.683
Yo que tu lo pienso dos veces
|
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
|
|
|
En línea
|
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
Desconectado
Mensajes: 6
|
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
|
|
|
En línea
|
|
|
|
EddyW
|
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.htmlPara cuando aprendas, usa Time en VBS para hacer eso.. SaluDOS!!!
|
|
|
En línea
|
|
|
|
jconnor
Desconectado
Mensajes: 6
|
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.htmlPara cuando aprendas, usa Time en VBS para hacer eso.. SaluDOS!!! Ok amigo, me pondre a revisar el tuto, gracias por la ayuda
|
|
|
En línea
|
|
|
|
Novlucker
Ninja y
Colaborador
Desconectado
Mensajes: 10.683
Yo que tu lo pienso dos veces
|
Ahora que lo miro detenidamente me doy cuenta de lo sencillo que es No es necesario que aprendas vbs, te dejo el code: 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) 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
|
|
« Última modificación: 6 Mayo 2009, 07:10 am por Novlucker »
|
En línea
|
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
Desconectado
Mensajes: 6
|
Ahora que lo miro detenidamente me doy cuenta de lo sencillo que es No es necesario que aprendas vbs, te dejo el code: 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) 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 problemaHola 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.
|
|
|
En línea
|
|
|
|
Novlucker
Ninja y
Colaborador
Desconectado
Mensajes: 10.683
Yo que tu lo pienso dos veces
|
|
|
|
En línea
|
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
Desconectado
Mensajes: 6
|
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
|
|
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
campos de fecha mysql y funciones de fecha php
PHP
|
SirLanceCC
|
9
|
9,352
|
3 Enero 2008, 12:36 pm
por Hans el Topo
|
|
|
Calcular dias entre Fecha A y Fecha B
« 1 2 »
.NET (C#, VB.NET, ASP)
|
Braayhaan
|
19
|
13,717
|
22 Julio 2010, 15:23 pm
por MANULOMM
|
|
|
Problema con Fecha !!
Ingeniería Inversa
|
TrashAmbishion
|
1
|
2,339
|
13 Marzo 2014, 20:44 pm
por tincopasan
|
|
|
Bloquear Programa a Cierta Fecha ??
Ingeniería Inversa
|
Ripzter
|
3
|
3,511
|
6 Septiembre 2014, 05:36 am
por XresH
|
|
|
Problema con formatos de fecha en c#
.NET (C#, VB.NET, ASP)
|
Yaldabaot
|
0
|
1,767
|
16 Agosto 2014, 06:35 am
por Yaldabaot
|
|