Club Delphi  
    FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 18-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Procedimiento que Cree una archivo de txt

Hola tengo una tabla con datos la cual me gustaria poderla exportar a un archivo de texto delimitando cada columna con espacios para mandarlo llamar de una pag. en C#.
Responder Con Cita
  #2  
Antiguo 18-03-2011
Avatar de Neftali [Germán.Estévez]
Neftali [Germán.Estévez] Neftali [Germán.Estévez] is offline
[becario]
 
Registrado: jul 2004
Ubicación: Barcelona - España
Posts: 18.275
Poder: 10
Neftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en brutoNeftali [Germán.Estévez] Es un diamante en bruto
Puedes hacerlo de forma manual o también utilizar algun componente de exportación como los mxExports (puedes encontrarlos en el FTP del Club) que te facilitarán el trabajo. ¿Tienes alguna preferencia?
__________________
Germán Estévez => Web/Blog
Guía de estilo, Guía alternativa
Utiliza TAG's en tus mensajes.
Contactar con el Clubdelphi

P.D: Más tiempo dedicado a la pregunta=Mejores respuestas.
Responder Con Cita
  #3  
Antiguo 20-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Hola que tal agradezco tu comentario pero el componente que me mencionas es para delphi y en este momento estoy manejando c#.net queria crearlo ahi pero no he podido darle la separacion entre columnas me crea el archivo txt y el contenido me aparece todo pegado. entonces como ultimo recurso queria saber si hay alguna forma que desde firebird pueda crear el archivo txt con el formato que quiero......
Responder Con Cita
  #4  
Antiguo 21-03-2011
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 23
guillotmarc Va por buen camino
Hola.

Tienes utilidades para hacerlo. NOTA: No necesita instalación, simplemente la ejecutas y ya puedes exportar una tabla a texto plano.

http://fbexport.sourceforge.net/

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #5  
Antiguo 22-03-2011
Avatar de rastafarey
rastafarey rastafarey is offline
Miembro
 
Registrado: nov 2003
Posts: 927
Poder: 21
rastafarey Va por buen camino
Resp

Create una UDF con dos parametros uno la ruta del archivo a aguardar y el otro la cadena de texto del txt.
__________________
Todo se puede, que no exista la tecnología aun, es otra cosa.
Responder Con Cita
  #6  
Antiguo 22-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Cita:
Empezado por rastafarey Ver Mensaje
Create una UDF con dos parametros uno la ruta del archivo a aguardar y el otro la cadena de texto del txt.

UDF no estoy familiarizada con el termino a que te refieres, un ejemplo por favor..
Responder Con Cita
  #7  
Antiguo 22-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Cita:
Empezado por guillotmarc Ver Mensaje
Hola.

Tienes utilidades para hacerlo. NOTA: No necesita instalación, simplemente la ejecutas y ya puedes exportar una tabla a texto plano.

http://fbexport.sourceforge.net/

Saludos.

Esta utilieria como se ejecuta, descargue el archivo lo descomprimi pero no se q mas de ahi.
Responder Con Cita
  #8  
Antiguo 22-03-2011
Avatar de oscarac
[oscarac] oscarac is offline
Miembro Premium
 
Registrado: sep 2006
Ubicación: Lima - Perú
Posts: 2.010
Poder: 20
oscarac Va por buen camino
una UDF es una Funcion Definida por el usuario llamese procedimiento o funcion
__________________
Dulce Regalo que Satanas manda para mi.....
Responder Con Cita
  #9  
Antiguo 22-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Cita:
Empezado por oscarac Ver Mensaje
una UDF es una Funcion Definida por el usuario llamese procedimiento o funcion
a ok un procedimieto pero para crear el archivo txt no se que funciones se utilizan o como es que se crea el archivo.
Responder Con Cita
  #10  
Antiguo 22-03-2011
Gallosuarez Gallosuarez is offline
Miembro
 
Registrado: feb 2007
Posts: 92
Poder: 18
Gallosuarez Va por buen camino
Talking Sugerencia ...

Amerika111:

Personalmente pienso que te estás complicando la vida. Si tu intención es exportar un archivo en formato de texto, para posteriormente leerlo en C#, ¿porque no te conectas directamente a firebird utilizando C#?, de esta manera puedes leer toda la información que tu quieras. Las opciones que te han mencionado los compañeros TODAS te sirven y TODAS son válidas, sin embargo algunas son mas complejas que otras (hacer una UDF no es muy sencillo que digamos, además que esta depende mucho de la plataforma donde esté montada tu base de datos, y en caso de que la quieras hacer que corra en varias plataformas, pues hay que tomar mas cosas en cuenta, ¿me explico?).

¿Porque no nos das mas información (ejemplo simplificado de las tablas donde quieres extraer datos y la forma en que la quieres procesar en C#), para así poderte hacer una sugerencia mas detallada de como puedes resolver tu problema.

Por otro lado, te menciono que hay un controlador ADO .Net para Firebird (te comento que yo ya hice pruebas y pude hacer un conexión con C# a Firebird utilizando MonoDevelop (plataforma MONO), lo cual me permitió que este pequeño ejemplo funcione tanto para Window como para Linux).

Saludos,
Gerardo Suárez Trejo

Última edición por Gallosuarez fecha: 22-03-2011 a las 18:33:24. Razón: Correción
Responder Con Cita
  #11  
Antiguo 22-03-2011
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 23
guillotmarc Va por buen camino
Cita:
Empezado por amerika111 Ver Mensaje
Esta utilieria como se ejecuta, descargue el archivo lo descomprimi pero no se q mas de ahi.
Se ejecuta desde la linea de comandos (y con ShellExecute la puedes ejecutar desde tu aplicación).

Si no me equivoco viene con un documento que indica los parámetros que se le pueden pasar.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #12  
Antiguo 22-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Cita:
Empezado por Gallosuarez Ver Mensaje
Amerika111:

Personalmente pienso que te estás complicando la vida. Si tu intención es exportar un archivo en formato de texto, para posteriormente leerlo en C#, ¿porque no te conectas directamente a firebird utilizando C#?, de esta manera puedes leer toda la información que tu quieras. Las opciones que te han mencionado los compañeros TODAS te sirven y TODAS son válidas, sin embargo algunas son mas complejas que otras (hacer una UDF no es muy sencillo que digamos, además que esta depende mucho de la plataforma donde esté montada tu base de datos, y en caso de que la quieras hacer que corra en varias plataformas, pues hay que tomar mas cosas en cuenta, ¿me explico?).

¿Porque no nos das mas información (ejemplo simplificado de las tablas donde quieres extraer datos y la forma en que la quieres procesar en C#), para así poderte hacer una sugerencia mas detallada de como puedes resolver tu problema.

Por otro lado, te menciono que hay un controlador ADO .Net para Firebird (te comento que yo ya hice pruebas y pude hacer un conexión con C# a Firebird utilizando MonoDevelop (plataforma MONO), lo cual me permitió que este pequeño ejemplo funcione tanto para Window como para Linux).

Saludos,
Gerardo Suárez Trejo

Hola que tal lo que tengo es lo siguiente tengo una tabla en firebird que vacio en un grid en C#.net y de C#.net lo que necesito es crear el archivo txt y darle una separacion entre columnas.


privatevoid prueba()
{

FbConnection cn = newFbConnection(FbDB);
cn.Open();

FbConnection cn1 = newFbConnection(FbDB);
cn1.Open();

DataSet ds = newDataSet();
FbDataAdapter ad = newFbDataAdapter("Select * FROM A_EXPORTAIMMS", cn);
ad.Fill(ds);


StringBuilder str = newStringBuilder();
for (int i = 0; i <= ds.Tables[0].Rows.Count - 1; i++)
{

for (int j = 0; j <= ds.Tables[0].Columns.Count - 1; j++)
{
str.Append(ds.Tables[0].Rows[i][j].ToString());
}
str.AppendLine();
}
Response.Clear();
Response.AddHeader(

"content-disposition",
"attachment;filename=FileName.txt");
Response.Charset =

"";
Response.Cache.SetCacheability(

HttpCacheability.NoCache);
Response.ContentType =

"application/vnd.text";
System.IO.

StringWriter stringWrite = new System.IO.StringWriter();
System.Web.UI.

HtmlTextWriter htmlWrite =
newHtmlTextWriter(stringWrite);
Response.Write(str.ToString());
Response.End();
cn.Close();
cn1.Close();
cn.Dispose();
cn1.Dispose();

}

Con este codigo si me extrae todos los datos del grid pero me crea el archivo sin espacion entre columnas me lo pone todo pegado, una linea corrida.


Responder Con Cita
  #13  
Antiguo 22-03-2011
amerika111 amerika111 is offline
Miembro
 
Registrado: nov 2009
Posts: 168
Poder: 0
amerika111 cantidad desconocida en este momento
Cita:
Empezado por Gallosuarez Ver Mensaje
Amerika111:

Personalmente pienso que te estás complicando la vida. Si tu intención es exportar un archivo en formato de texto, para posteriormente leerlo en C#, ¿porque no te conectas directamente a firebird utilizando C#?, de esta manera puedes leer toda la información que tu quieras. Las opciones que te han mencionado los compañeros TODAS te sirven y TODAS son válidas, sin embargo algunas son mas complejas que otras (hacer una UDF no es muy sencillo que digamos, además que esta depende mucho de la plataforma donde esté montada tu base de datos, y en caso de que la quieras hacer que corra en varias plataformas, pues hay que tomar mas cosas en cuenta, ¿me explico?).

¿Porque no nos das mas información (ejemplo simplificado de las tablas donde quieres extraer datos y la forma en que la quieres procesar en C#), para así poderte hacer una sugerencia mas detallada de como puedes resolver tu problema.

Por otro lado, te menciono que hay un controlador ADO .Net para Firebird (te comento que yo ya hice pruebas y pude hacer un conexión con C# a Firebird utilizando MonoDevelop (plataforma MONO), lo cual me permitió que este pequeño ejemplo funcione tanto para Window como para Linux).

Saludos,
Gerardo Suárez Trejo
la conexion no es el problema si conecto la tabla con c#.net y la vacio en un grid lo que me falta es enviar la info del grid al txt. separando columanas. Coloque el codigo que utilizo en la parte de arriba
Responder Con Cita
  #14  
Antiguo 23-03-2011
Gallosuarez Gallosuarez is offline
Miembro
 
Registrado: feb 2007
Posts: 92
Poder: 18
Gallosuarez Va por buen camino
Recomendaciones ...

Amerika111:


¡Aja!, me imagina algo así. Primero, recomiendo que leas la guía de estilo de este sitio (te dice, entre otras cosas, como debes de plantear tus preguntas, para que los compañeros [que tienen mucha paciencia y una disposición del tamaño del mundo, te puedan ayudar a resolver tu problema de la mejor manera]).

Segundo, ya te percataste que tu pregunta, al final de cuentas, no tiene nada que ver con Firebird (tiene que ver mas con C#). Bueno, en fin.

Tercero, voy a hacer lo siguiente: voy a copiar tu código de C# y voy a poner en forma textual que es lo que tienes que hacer (disculpa, pero no conozco dicho lenguaje de programación [hasta el momento solo he hecho una sola prueba y la hice utilizando un copy-paste]), así que tu disculparás.

Código:
privatevoid prueba() 
{

FbConnection cn = newFbConnection(FbDB); 
cn.Open();

FbConnection cn1 = newFbConnection(FbDB); 
cn1.Open();

DataSet ds = newDataSet();
FbDataAdapter ad = newFbDataAdapter("Select * FROM A_EXPORTAIMMS", cn); 
ad.Fill(ds);


StringBuilder str = newStringBuilder();
for (int i = 0; i <= ds.Tables[0].Rows.Count - 1; i++) 
{

  for (int j = 0; j <= ds.Tables[0].Columns.Count - 1; j++) 
  {
     str.Append(ds.Tables[0].Rows[i][j].ToString());
     // concatenar a tu variable str el separador que quieres entre columnas
     // Excepto a la última columna. 
    // algo así como esto: str = str + ','     (si quieres que el separdor sea una coma     
  }
  str.AppendLine();
  // concatenas a tu variable str un Carriage Return + Line Feed
  // algo así como esto: str = str + CHR(13) + CHR(10)  
}
Response.Clear();
Response.AddHeader(

"content-disposition",
"attachment;filename=FileName.txt"); 
Response.Charset =

""; 
Response.Cache.SetCacheability(

HttpCacheability.NoCache); 
Response.ContentType =

"application/vnd.text"; 
System.IO.

StringWriter stringWrite = new System.IO.StringWriter(); 
System.Web.UI.

HtmlTextWriter htmlWrite =
newHtmlTextWriter(stringWrite); 
Response.Write(str.ToString());
Response.End();
cn.Close();
cn1.Close();
cn.Dispose();
cn1.Dispose();

}
Espero que esto te ayude un poco.

Saludos y más atención para la próxima.
Atte:
Gerardo Suárez Trejo
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
condicionar un procedimiento dentro de otro procedimiento yossi Varios 7 17-05-2010 10:47:14
Problemas con un job que cree Nomed MS SQL Server 6 27-03-2009 20:09:27
Frames, esperar a que cree sus controles paubar Varios 12 02-09-2007 22:23:55
Cree el EXE en delphi 5 y lo corro en XP , marca error , alguna idea? kamik Varios 10 22-12-2005 17:03:10
Ayuda, como llamar a un procedimiento desde otro procedimiento? Ariatna Varios 1 01-02-2005 04:05:35


La franja horaria es GMT +2. Ahora son las 08:05:22.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi