Funcion reemplazar en Visual basic 6.0

Iniciado por merlin, 23 Mayo 2007, 11:19 AM

0 Miembros y 2 Visitantes están viendo este tema.

merlin

Como se podria hacer en visual una funcion similar a la funcion reemplazar texto del bolc de notas,es decir,que encuentre una cadena en un fichero de texto que va leyendo y la reemplace por otra.
Lo de leer el fichero de texto ya lo tengo hecho,pero no se como hacer para reemplzar cadenas,yo tenia entendido que para hacer eso (al menos en C),tienes que modificar el valor del final del fichero pq esta va a cambiar una vez que hagas el Replace.
Un saludo y gracias por adelantado
100% ESPAÑOL

~~


merlin

Ok tio,muchas gracias,me di cuenta justo despues de enviar el post de que era esa funcion la que estaba buscando.
Un saludo
100% ESPAÑOL

merlin

Vuelvo a reflotar la pregunta pq aun no lo tengo muy claro.
Vale,la funcion que necesito es Replace.
Es decir,yo abro un fichero de lectura,busco una determinada cadena y esa la quiero reemplazar por otra,como seria?
Pq la funcion replace lo que hace es devolverme una nueva cadena ,en la que una cadena especificada se reemplazo por otra,
pero como hago para sustituirla en el fichero,que lo tengo abierto de solo lectura,si ademas esa funcion lo unico que hace es devolverme una nueva cadena?
Espero haberme explicado bien.
Un saludo.
Si me lo explicase alguien con un ejemplo sencillo se lo agradeceria

Un saludo
100% ESPAÑOL

~~

Mira, un ejemplo facil con un textbox en vez de un archivo (luego es adaptarlo nada mas ;))

Private Sub Command1_Click()
Dim Final As String
Final = Replace(Text1.Text, "HOLA", "¬¬'")
Text1.Text = Final
End Sub


Imaginate q en el textbox pone esto:
CitarHOLAasfksdahnfkdsa
sdagfsda
gsdg
dsdgsgsdgHOLA

Cuando le des al boton deberia kedarte esto:
Citar¬¬'asfksdahnfkdsa
sdagfsda
gsdg
dsdgsgsdg¬¬'

Pues haz eso con un archivo en vez de con el cuadro de texto xDD

merlin

Ya,pero como guardo el resultado en el fichero?
Por que lo unico que se me ocurre es escribirlo,pero asi no estoy reemplazando nada,lo estoy añadiendo al final,y lo que tengo que hacer es borrar esa cadena que estoy buscando y en esa misma linea escribir la nueva cadena.
Con el replace obtengo una cadena nueva que tengo que escribir en el fichero que abri,que tiene muchas lineas,osea que no lo puedo hacer como si lo estuviese haciendo en un textbox,no se si me explico.
No me podrias poner un pequeño ejemplo en el que lo hiciseses con un fichero?
Gracias por contestar y a ver si alguien me puede echar un cable
Salu2
100% ESPAÑOL

~~

Lees el fichero entero:
open ruta for binary as #1
dim todo as string
todo = space(lof(1))
get #1,,todo
close #1


Y ahora q tienes todo el fichero en la variable todo aplicas el codigo anterior, con lo q tu kieras sustituir claro  :xD
Dim Final As String
Final = Replace(todo, "HOLA", "¬¬'")


Ahora borras el fichero q has leido anteriormente:
kill ruta
Siendo ruta la ruta del fichero claro

Finalmente creas un nuevo fichero con la cadena ya sustituida:
open ruta for binary as #1
put #1,final
close #1


Y ya esta  :xD :xD
1S4ludo

merlin

Ok,gracias tio,lo que no veo muy claro es lo de meter todo el texto del fichero en un string,no se me desbordaria el string?
Gracias por contestar y salu2
100% ESPAÑOL

vivachapas

no...
el string tiene una capacidad (creo q era) de 65500 y algo...
yo cargue archivos pesados en las string y nucna se produjo un desbordamiento... prueba seguro q no pasa nada

Hendrix

No se desbordara por la siguiente expresion:

todo = space(lof(1))

lo que hace eso es modificar el tamaño de la string (por defecto es 4 byts creo) y le establece un tamaño para que quepa justo el tamaño del archivo (LOF = Long of File) y el 1 indica el numerador del archivo que se trata ya que lo abriste con open..blablabla... #1)).

Asi no hay desbordamiento... ;) ;)

Un Saludo.  ;)

"Todos los días perdemos una docena de genios en el anonimato. Y se van. Y nadie sabe de ellos, de su historia, de su peripecia, de lo que han hecho, de sus angustias, de sus alegrías. Pero al menos una docena de genios se van todos los días sin que sepamos de ellos". - Juan Antonio Cebrián