|
Mostrar Temas
|
Páginas: [1] 2
|
1
|
Programación / Scripting / [VBS] Detectar nombre en renombrado masivo
|
en: 28 Julio 2015, 00:04 am
|
Hola, lo que quiero hacer prácticamente ya está hecho, sólo me falta hacer la tarea algo más inteligente al detectar si un nomobre ya existe para evitar que por ejemplo si quiero cambiar "Luis" por "José Luis" provoque "José José Luis". La base es tirar de un txt, donde habrá un listado por líneas, en cada cual habrá un par de palabras, indicando la palabra a cambiar y la nueva palabra: Luis-José Luis. Código: Option Explicit Dim fso, fso2, strNombreAnterior, StrNombreNuevo, RutaNombres, RutaArchivo, ListaArchivos, Archivo, strContenidoAnterior, strContenidoNuevo, NombresFila, FilaPartida,objFile,value, word Set fso=CreateObject("Scripting.FileSystemObject") Set fso2=CreateObject("Scripting.FileSystemObject") Const Lectura = 1 Const Escritura = 2 RutaNombres="C:\Users\Isra\Desktop\lista.txt" RutaArchivo="C:\Users\Isra\Desktop\Prueba.txt" 'Establecemos los objetos Set ListaArchivos = fso.OpenTextFile(RutaNombres,Lectura) Set Archivo=fso2.OpenTextFile(RutaArchivo,Lectura) 'Leemos el archivo a modificar strContenidoNuevo=Archivo.ReadAll Archivo.close Set objFile = fso.OpenTextFile(RutaArchivo, Escritura) 'Lee línea por línea para saber los valores a modificar en un archivo de texto Do Until ListaArchivos.AtEndOfStream 'Lee la línea entera NombresFila = ListaArchivos.ReadLine 'Partimos la línea asignando cada valor a un array FilaPartida=split(NombresFila ,"-") 'Asignamos a cada variable su valor del array por línea strNombreAnterior=Trim(cstr(FilaPartida(0))) strNombreNuevo=Trim(cstr(FilaPartida(1))) 'Comprobamos valores 'wscript.echo strNombreAnterior 'wscript.echo strNombreNuevo value = InStr(strContenidoNuevo, strNombreNuevo) 'wscript.echo value [color=red]if value <> 1 then [/color] strContenidoNuevo=Replace(strContenidoNuevo, strNombreAnterior, strNombreNuevo,1,-1,0) [color=red]end if [/color] Loop 'wscript.echo strContenidoNuevo ListaArchivos.close objFile.WriteLine strContenidoNuevo objFile.Close
El problema con value = InStr(strContenidoNuevo, strNombreNuevo) es que al detecta que existe ya no interpreta ninguna otra más con el nombre StrNombreNuevo. Si quito la parte en rojo, cada vez que ejecute los nombres compuesto iran ganando el primer nombre reitativamente. Pensé en hacer un bucle tal que: for each word in split(strContenidoNuevo, "") value = InStr(strContenidoNuevo, strNombreNuevo) 'wscript.echo value [color=red]if value <> 1 then [/color] strContenidoNuevo=Replace(strContenidoNuevo, strNombreAnterior, strNombreNuevo,1,-1,0) [color=red]end if [/color] next
Sin embargo, el resultado no es el esperado. Imagino que será una trivialidad pero ahora mismo estoy ofuscado ^^'. Gracias.
|
|
|
2
|
Programación / Scripting / [BATCH] Copiado con confirmacion de correcta escritura
|
en: 24 Octubre 2013, 02:13 am
|
Hola a todos, he creado un bat para copiar una serie de archivos en un disco externo y mi intencion es que me saque en pantalla los archivos que se han copiado y si ha habido fallos o no. El script es el siguiente, sin embargo, no se si realmente cumple el objetivo del script o conceptualmente me he equivocado. @echo off Title Copiar if not exist "I:\Carpeta" md "I:\Carpeta" for %%@ in (*.mkv) do ( copy "%%@" "I:\Carpeta" /Y 1>nul & Echo El archivo: "%%@" fue copiado correctamente. || Echo Hubo un fallo al copiar el archivo "%%@". echo. ) pause>nul&exit
He pensado que si está mal, quizás con %ERRORLEVEL% podría sería mejor pero ya implementarlo a esa linea se me escapa. Gracias.
|
|
|
3
|
Programación / Scripting / [Python] Scrollbar dentro de un listbox
|
en: 20 Agosto 2013, 05:48 am
|
Bueno estoy diseñando una UI para un programa... todo es relativamente precario pues estoy aprendiendo poco a poco como manejarlo. He conseguido insertar un scrollbar dentro del listbox, sin embargo el problema radica en que el scrollbar no desaparece nunca, ni cuando no hay elementos en el listbox. Estoy probando usando Grid, imagino que con pack se puede hacer de otra manera, lo digo pq por ahora me interesa hacerlo con este comando. El codigo: import os, sys import win32api import platform import gettext import locale import sys from time import sleep #GUI para EACUI try: import tkinter from tkinter import * except ImportError: raise ImportError("Se requiere el modulo Tkinter") #Configure gettext Define the '_()' function APP_NAME = "EACUI" LOCALE_DIR = ('C:\Locale\es\LC_MESSAGES') gettextt = gettext.translation(APP_NAME, LOCALE_DIR,fallback=True) _ = gettextt.gettext #Ventana root = tkinter.Tk(screenName=None, baseName=None, className='Tk', useTk=1) '''Titulos''' root.wm_title("Eac3to GUI v0.0") #root.title("Eac3to GUI v0.0") root.wm_frame() '''Etiqueta''' #etiqueta=tkinter.Label(root,text="Eac3to GUI v0.0") #etiqueta.grid(row=1, column=1) '''Dimension ventana''' root.wm_maxsize(1000, 1000) root.wm_minsize(640,640) root.wm_geometry('640x640') root.wm_iconbitmap('.\icon.ico') '''Menus''' #File menu = tkinter.Menu(root) root.config(menu=menu) menu1_1 = tkinter.Menu(menu, tearoff=0) menu.add_cascade(label=_("File"), menu=menu1_1) menu1_1.add_command(label=_("Open")) menu1_1.add_command(label=_("Close")) #Options menu1_2 = tkinter.Menu(menu, tearoff=0) menu.add_cascade(label=_("Options"), menu=menu1_2) menu1_2.add_command(label=_("Setup"),command=lambda: setup(_("Setup"))) menu1_2.add_separator() menu1_2_1 = tkinter.Menu(menu1_2, tearoff=0) menu1_2.add_cascade(label=_("Language"), menu=menu1_2_1) menu1_2_1.add_command(label=_("English"),command=lambda: language(_("English"))) menu1_2_1.add_command(label=_("Spanish"),command=lambda: language(_("Spanish"))) #Help menu1_3 = tkinter.Menu(menu1_2, tearoff=0) menu.add_cascade(label=_("Help"), menu=menu1_3) menu1_3.add_command(label=_("About"),command=lambda: about(_("About"))) '''Ventana de carga con scrollbar interno usando Grid''' text = tkinter.Listbox(root) text.grid(padx=10,pady=10) text.bindtags((text, root, "all")) #for i in range(20): #text.insert(i,i) scrl = Scrollbar(root, command=text.yview) text.config(yscrollcommand=scrl.set) scrl.grid_rowconfigure(10) #scrl.grid(ipadx=200,ipady=20,sticky='e',rowspan=5) scrl.grid(in_=text,ipadx=200,ipady=20,sticky='ns') '''Ventana de carga''' #windows_load=tkinter.Text(root,height = 1, width=int(root.winfo_width())-580,font=("Times", 12),state=tkinter.NORMAL, cursor='arrow',insertwidth=2,exportselection=1) #windows_load=tkinter.Listbox(root,height=10,width=int(root.winfo_width())-580) #windows_load.bindtags((windows_load, root, "all")) #for i in range(20): #windows_load.insert(i,i) #windows_load.pack(anchor='nw',side=TOP, fill=Y, expand=FALSE,padx=10,pady=10) '''Ejecucion''' root.mainloop()
¿En donde estoy metiendo la pata?
|
|
|
4
|
Programación / Scripting / [Python] Aplicacion multilenguaje
|
en: 15 Agosto 2013, 04:34 am
|
Hola a todos, pues nada estoy intentando hacer una aplicacion GUI para un programa de codificacion de audio. El caso es que me ha llamado siempre la atención, desde que llevo varios años traduciendo el programa mkvmerge, el poder usar GNU. Estoy poco a poco intentando hacer pruebas para poder traducir la interfaz y por ahora dar las opciones de dos lenguajes, English y Español. El codigo que llevo es este: #------------------------------------------------------------------------------- # Name: EACUI # Purpose: Audio encoding with EAC3TO # # Author: Overdrive80 # # Created: 13/08/2013 # Copyright: (c) Overdrive80 2013 # Licence: <your licence> #------------------------------------------------------------------------------- import os, sys import win32api import platform import gettext import locale import sys #Configure gettext Define the '_()' function def set_gettext(): APP_NAME = "EACUI" LOCALE_DIR = ('C:\Locale\es\LC_MESSAGES') t = gettext.translation(APP_NAME, LOCALE_DIR,fallback=True) _ = t.gettext def main(): #Inicializacion de Gettext set_gettext() '''Create a list of asociated programs''' lista_programas=['eac3to'] '''Check arquitecture''' def is_x64(): arquitectura=platform.architecture() if arquitectura[0] == '64bit': #print "Tu sistema es de 64 bits." return True else: #print "Tu sistema es de 32 bits." return True '''Seek path by default of installating''' def find(ruta, program): for root,dirs,files in os.walk(ruta): for name in files: if program+'.exe'==name: path=os.path.join(root, name) return path PATH_DEFAULT='C:\\' for programa in lista_programas: path=find(PATH_DEFAULT, programa) if path != None: ruta_bus=os.path.split(path) print (_('File found %s, in the path %s.')) % programa, ruta_bus[0] print (_('Would you like to set this path as access by default to program %s?')) % programa else: print (_("Not file found %s.")) % programa print (_('Would you like set handle program´s path?')) main()
El archivo "es.mo" es este: https://dl.dropboxusercontent.com/u/19135067/es.moEl problema radica cuando intento ejecutar el script de manera que coja el "es.mo", me da este error: Es algo curioso pq he podido generar correctacmente el archivo "es.pot" con: set path=path;C:\Python33\ set /p label="Inserte la etiqueta del idioma (p.e.: es ): " python "C:\Python33\tools\i18n\pygettext.py" -d %label% -o %label%.pot %1
Estoy usando la version 3.2 de python pq la 2, al parecer no tiene implementando gettext. Espero que me podais echar un cable. Saludos. EDITO: He conseguido fijar ese problema declarando debajo de la importacion de modulos: "_ =None". Sin embargo, ahora me encuentro este problema: Hubiera escrito el codigo de otra manera pero me daba fallo al generar el archivo pot, porque gettext no admite expresiones debe ser un formato string. EDITO2: Solucionado, al menos se ejecuta. Al parecer, todo el fallo ha sido por meter en una funcion el codigo de gettext, cuando debe ir fuera del bloque main. Lo que está tachado y que hice no sirve.
|
|
|
5
|
Programación / Scripting / [Python] Listar Archivos Carpeta
|
en: 11 Agosto 2013, 22:46 pm
|
Bueno... hace poco y a modo de hobby me puse a aprender este lenguaje, y aunque soy un mega noob en esto me permito postear un código para quien quiera criticarlo positiva o negativamente... asi podré seguir mejorando. Este codigo permite listar los archivos de una carpeta que este en la misma ruta que el script, y lo guarda en un txt. He añadido y no he quitado, un parametro simple de control de ejecucion, a modo de depuracion... aunque podia haber hecho algun try... pero me gustan las ventanitas jiji #------------------------------------------------------------------------------- # Name: Overdrive # Purpose: Listar archivos directorio en un txt # # Author: Overdrive # # Created: 10/08/2013 # Copyright: (c) Overdrive 2013 # Licence: Free #------------------------------------------------------------------------------- #import fnmatch import os from tkinter import messagebox import tkinter #Creamos una clase para la ventana de control depuración class Msgbox(object): #""" Constructor """ def __init__(self, text): self.text=text window = tkinter.Tk() window.wm_withdraw() def msg(self): messagebox.showinfo("Ventana de depuración", self.text) def escribir(name): #Creamos el objeto del archivo de texto fd = os.open( name, os.O_RDWR|os.O_CREAT ) mi_archivo=os.fdopen(fd,"r+") #Grabamos cada archivo del directorio en el txt, exceptuando el script for file in os.listdir('.'): if file[-2:] != 'py' and file[-3:] != 'txt': mi_archivo.write(str(file)+"\n") #Cerramos el archivo creado mi_archivo.close() def main(): #Comprobamos si existe .txt y sino lo creamos if os.path.isfile(str(os.curdir)+"\lista.txt")==False: ventana=Msgbox("No existe el fichero.") ventana.msg() escribir("lista.txt") else: ventana=Msgbox("Si existe el fichero.") ventana.msg() os.remove('lista.txt') escribir("lista.txt") main()
|
|
|
6
|
Programación / Scripting / QPF to Chapter file
|
en: 12 Julio 2013, 05:48 am
|
Hola buenas, estaba intentando hacer un conversor de archivos qpf files (que es un txt con otra extensión) para calcular una serie de codigos de tiempo en base a un numero prefijado de 23.976 frames por segundo. El caso es que nada mas empezar no me ejecuta la tarea mas basica que es motrar en la consola las lineas del qpf. El código es este: FOR /F "tokens=*" %%A IN ("C:\Users\Isra\Desktop\Nueva carpeta\10. QPFILE_NAME.txt" ) DO CALL:Tratar " %%A" :Tratar
El formato de un archivo qpf es: 0 K -1 2616 K -1 16072 K -1 16384 K -1 32440 K -1 34768 K -1 Entonces necesito coger cada numero, tratarlo durante el proceso del for, calcular el codigo de tiempo, e ir almacenandolo en otro txt. El algoritmo sería algo como: Codigo de tiempo=2616*0,0417083sg=109,1089128sg/60=1,81848188=1min+0,81848188 resto_tiempo=0,81848188*60=49,1089128sg=49sg+109ms total 1min49sg109ms-->00:01:49.109 Tras calcular el primer resultado tendria que discenir si x>=3600 entonces el resultado que da seria en horas, si x>=60 daria en minutos, x<60 en segundos. Vamos, pero que me gustaria saber pq no me lista los numeros. Tengo windows8, por si afecta en algo.
|
|
|
7
|
Programación / Scripting / [BAT] Buscar archivo con un string indicado
|
en: 24 Enero 2013, 05:51 am
|
Buenas, estoy haciendo una prueba para despues poder implementar una movida absurda de las que me hago en casa ^^. El caso es que intento buscar un archivo por su string para que me devuelva la ruta completa, pero al hacer la comparacion con el IF, el caso es sensitivo. Entonces necesitaria hacer un lowcase. Me explicare mejor con el codigo, jeje set /p nombre="Introduzca el nombre a buscar: "
for /r c:\ %%@ in ("%nombre%.*") do (
if "%%~n@"=="%nombre%" echo %%@
)
Por ejemplo estoy buscando la palabra "megui", pero este archivo esta almacenado con el string "MeGUI". Entonces, si no inserto en el set, lo mismo no me devuelve ningun resultado.
|
|
|
8
|
Programación / Scripting / [Batch] Buscar carpeta donde se encuentra un portable
|
en: 19 Noviembre 2012, 04:06 am
|
Buenas, por motivos un tanto raros he creado este script. Mi duda mas bien es para optimizar el codigo a algo que seguramente se pueda hacer mas sencillo que todo el codigo que he usado, y que ahora pongo. Principalmente sirve para localizar la instalacion de un programa portable, en este caso VirtualDub. :: Nos situamos en la siguiente carpeta cd /d " %homedrive%\Program Files (x86 )" :Listamos directorios de la carpeta actual y comprobamos si se encuentra Virtualdub en ella dir /b > " %temp%\info_vdub.txt" ::Buscamos coincidencia de string, creamos un archivo de texto para valernos del mensaje de errorlevel. Find /i "virtualdub" < "%temp%\info_vdub.txt" > "%temp%\StringCheck.txt" ) ::Borramos archivos temporales del " %temp%\StringCheck.txt" del " %temp%\info_vdub.txt" :: Nos situamos en la siguiente carpeta y hacemos mas de lo mismo cd /d " %homedrive%\Program Files" dir /b > " %temp%\info_vdub.txt" Find /i "virtualdub" < "%temp%\info_vdub.txt" > "%temp%\StringCheck.txt" ) ::Borramos archivos temporales del " %temp%\StringCheck.txt" del " %temp%\info_vdub.txt" ::Info en pantalla Echo VirtualDub esta instalado en: ) )
|
|
|
9
|
Programación / Scripting / [Batch] Conservar caracteres especiales usando delayedexpansion
|
en: 25 Octubre 2012, 18:40 pm
|
Buenas, en esta ocasion estoy haciendo un listado de unos archivos matroska, y usando el for con tokens, para seleccionar la parte a guardar en la lista. Al tener que usar enableddelayedexpasion, ciertos caracteres son destruidos. He intentado cambiar el chcp pero sin resultado. El codigo es este: @echo off Title Listar nombres capitulos Setlocal EnableDelayedExpansion
rem CHCP 850 >nul if exist "lista.txt" (erase "lista.txt")
for /f "tokens=2 delims=[]" %%i in ('dir /b /o:n "*.mkv"') do ( set "nom=%%i"
echo !nom:~1! >> "lista.txt" )
pause Lo curioso es que si lo ejecuto desde cmd, se muestra perfectamente con sus caracteres. Original Queda algo asi sin extenderme:
|
|
|
10
|
Programación / Scripting / [Batch] Instalador selectivo de updates Windows
|
en: 13 Octubre 2012, 21:57 pm
|
Hola a todos, el caso es que ya sabeis lo tedioso que puede resultar aplicar las updates de windows manualmente, o de forma automatica cuando su numero asciende a 700 revisiones, como es mi caso. El agente de updates de windows solo me requiere 78 para que este protegido por lo que solo quiero instalar esas. Para ello he utilizado este codigo, para listas todas las updates disponibles: @Echo off Title Instalador con lista set ruta=F:\HDD negro\Utiles y programas\Programas De Microsoft\Microsoft_Updates\updates\
for /f %%i in ('dir /b /o:n "*kb*.msu"') do (
if not exist "updates_total.txt" ( echo %%i >> "updates_total.txt" ) )
::2 parte for /f "tokens=1 delims=*" %%i in (updates.txt) do (find /i "%%i" "%ruta%updates_total.txt" >> "updates_instalar.txt" )
El archivo updates.txt tiene un formato asi: *KB2655992* *KB2691442* *KB2698365* *KB3719985* *KB2506212* *KB2507618* *KB2536276* *KB3544893* *KB2560656* *KB2564958* El caso es que find funciona bien, pero lo que devuelve en el archivo "updates_instalar.txt" tiene un formato muy raro, y yo esperaba que fuese simplemente el nombre de la revision, para posteriormente usar este archivo de texto en otro FOR, y las ejecute. El formato erroneo es este: ---------- F:\HDD NEGRO\UTILES Y PROGRAMAS\PROGRAMAS DE MICROSOFT\MICROSOFT_UPDATES\UPDATES\UPDATES_TOTAL.TXT Windows6.1-KB2655992-x64.msu
---------- F:\HDD NEGRO\UTILES Y PROGRAMAS\PROGRAMAS DE MICROSOFT\MICROSOFT_UPDATES\UPDATES\UPDATES_TOTAL.TXT Windows6.1-KB2691442-x64.msu
..... Imagino que habra alguna manera de eliminar los encabezados esos. Inicialmente pense que podria kizas, listar las updates que el agente de windows update te informa para instalar, pero no tengo ni idea de como se podria hacer, quizas con wmic. Lo que si he visto por la red es la manera de listar las updates instaladas... Gracias de antemano.
|
|
|
|
|
|
|