Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   Procedimiento que Cree una archivo de txt (https://www.clubdelphi.com/foros/showthread.php?t=72914)

amerika111 18-03-2011 18:15:25

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#.

Neftali [Germán.Estévez] 18-03-2011 18:48:37

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?

amerika111 20-03-2011 01:40:57

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......

guillotmarc 21-03-2011 11:50:51

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.

rastafarey 22-03-2011 02:57:23

Resp
 
Create una UDF con dos parametros uno la ruta del archivo a aguardar y el otro la cadena de texto del txt.

amerika111 22-03-2011 16:49:43

Cita:

Empezado por rastafarey (Mensaje 394236)
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..

amerika111 22-03-2011 16:55:24

Cita:

Empezado por guillotmarc (Mensaje 394157)
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.

oscarac 22-03-2011 16:59:05

una UDF es una Funcion Definida por el usuario llamese procedimiento o funcion

amerika111 22-03-2011 17:19:49

Cita:

Empezado por oscarac (Mensaje 394266)
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.

Gallosuarez 22-03-2011 18:31:42

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

guillotmarc 22-03-2011 19:23:31

Cita:

Empezado por amerika111 (Mensaje 394265)
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.

amerika111 22-03-2011 20:14:40

Cita:

Empezado por Gallosuarez (Mensaje 394279)
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.



amerika111 22-03-2011 20:39:08

Cita:

Empezado por Gallosuarez (Mensaje 394279)
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

Gallosuarez 23-03-2011 02:03:26

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


La franja horaria es GMT +2. Ahora son las 03:30:49.

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