Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   Archivo en el mismo directorio que la aplicacion (https://www.clubdelphi.com/foros/showthread.php?t=11625)

Sotrono 19-06-2004 05:11:19

Archivo en el mismo directorio que la aplicacion
 
Hola como va?
Estoy trabajando con una base de datos acces, y uso los componentes TAdoConnection, y TAdoTable.
Lo que quiero es que en me busque la base de datos en el mismo directorio en el que esta el archivo ejecutable.
Hay alguna forma de hacer esto?

jachguate 19-06-2004 06:08:43

No se cómo será en el caso de access, pero hay dos planteamientos posibles:
  • Asignale a tu cadena de conexión una ruta relativa. Es decir, en lugar de indicar una ruta completa como 'c:\programa\base.mdb' asignale solamente 'base.mdb'. Esto no funciona en motores como interbase, que tienen un proceso servidor corriendo en su propia ruta, pero es probable que si funcione con access.
  • En tiempo de ejecución, podes averiguar la ruta donde corre tu ejecutable con ExtractFilePath(application.ExeName), de manera que podes usar esta ruta para asignar la cadena de conexión.
Solo debo aclarar que en el primer caso, la ruta no es relativa a la ruta del ejecutable, sino al directorio actual de la aplicación, que en el caso de iniciar con un acceso directo, es el que se coloca en "iniciar en".

Hasta luego.

;)

salvica 19-06-2004 11:26:33

Hola a tod@s :)
Yo lo resolvia creandome una variable global, asignarla la ruta del ejecutable y guardandola en un ".ini" dentro del directorio de trabajo del programa para leerla de nuevo (en el "Create" del form) cada vez que corro el programa
[code_delphi]
var
Form1 : TForm;
DIR_TRABAJO : string; // global al proyecto
...

procedure TWin_Main.Form_OnCreate(Sender: TObject);
var
FileIni : TFileIni;
tmpRuta : string;
begin
tmpRuta := GetCurrentDir;
fileIni := TFileIni.Create( tmpRuta + '\parametros.ini' );
DIR_TRABAJO := fileIni.ReadString( 'DBF', 'DIR_TRABAJO', '' );
if( Trim(DIR_TRABAJO)='' ) then begin
{ crear el nuevo directorio de trabajo } fileIni.WriteString( 'DBF', DIR_TRABAJO, tmpRuta+'\DBF' );
DIR_TRABAJO := tmpRuta+'\DBF';
end;
fileIni.Free;
ForceDirectories( DIR_TRABAJO ); // forzar el directorio por si se cambia la ruta
...
end;
[/code_delphi]

DarkByte 20-06-2004 21:01:16

Salvica, ya te he puesto el código con las etiquetas [ Delphi ] y [/ Delphi], recuerda que no es [ Code_Delphi ] sino [ Delphi ] a secas, pera la próxima vez ;)
Código Delphi [-]
 var
   Form1 : TForm;
   DIR_TRABAJO : string; // global al proyecto
   ...
 
 procedure TWin_Main.Form_OnCreate(Sender: TObject);
 var
   FileIni : TFileIni;
   tmpRuta : string;
 begin
   tmpRuta := GetCurrentDir;
   fileIni := TFileIni.Create( tmpRuta + '\parametros.ini' );
   DIR_TRABAJO := fileIni.ReadString( 'DBF', 'DIR_TRABAJO', '' );
   if( Trim(DIR_TRABAJO)='' ) then begin
     { crear el nuevo directorio de trabajo }    fileIni.WriteString( 'DBF', DIR_TRABAJO, tmpRuta+'\DBF' );
     DIR_TRABAJO := tmpRuta+'\DBF';
   end;
   fileIni.Free;
   ForceDirectories( DIR_TRABAJO ); // forzar el directorio por si se cambia la ruta
   ...
 end;

weke 21-06-2004 07:16:13

Buenas!

Yo tengo la conexión a mi base de datos de la misma manera. Utilizo una variable global para asignarle la ruta de la base de datos en el principal:
Código Delphi [-]
ruta:=ExtractFilePath(Application.ExeName)+'nombre.mdb';
y después le asigno esta ruta al ADOConnection antes de hacer la conexión con la base de datos.
Código Delphi [-]
procedure TDataModule1.ADOConnection1BeforeConnect(Sender: TObject);
begin
  ADOConnection1.ConnectionString:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+ Principal.ruta+';Mode=ReadWrite;Extended Properties="";Persist Security Info=False';
end;
Espero que te sirva.
Saludos!!

Sotrono 26-06-2004 04:39:04

Ok, Muchas gracias por la ayuda, que me vino muy bien..


La franja horaria es GMT +2. Ahora son las 20:52:39.

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