* * * *

Privacy Policy

Blog italiano

Clicca qui se vuoi andare al blog italiano su Lazarus e il pascal.

Forum ufficiale

Se non siete riusciti a reperire l'informazione che cercavate nei nostri articoli o sul nostro forum vi consiglio di visitare il
Forum ufficiale di Lazarus in lingua inglese.

Lazarus 1.0

Trascinare un file nel programma
DB concetti fondamentali e ZeosLib
Recuperare codice HTML da pagina web
Mandare mail con Lazarus
Stabilire il sistema operativo
Esempio lista in pascal
File INI
Codice di attivazione
Realizzare programmi multilingua
Lavorare con le directory
Utilizzare Unità esterne
TTreeView
TTreeview e Menu
Generare controlli RUN-TIME
LazReport, PDF ed immagini
Intercettare tasti premuti
Ampliare Lazarus
Lazarus e la crittografia
System Tray con Lazarus
UIB: Unified Interbase
Il file: questo sconosciuto
Conferma di chiusura di un applicazione
Liste e puntatori
Overload di funzioni
Funzioni a parametri variabili
Proprietà
Conversione numerica
TImage su Form e Panel
Indy gestiore server FTP lato Client
PopUpMenu sotto Pulsante (TSpeedButton)
Direttiva $macro
Toolbar
Evidenziare voci TreeView
Visualizzare un file Html esterno
StatusBar - aggirare l'errore variabile duplicata
Da DataSource a Excel
Le permutazioni
Brute force
Indy 10 - Invio email con allegati
La gestione degli errori in Lazarus
Pascal Script
Linux + Zeos + Firebird
Dataset virtuale
Overload di operatori
Lavorare con file in formato JSON con Lazarus
Zeos ... dietro le quinte (prima parte)
Disporre le finestre in un blocco unico (come Delphi)
Aspetto retrò (Cmd Line)
Lazarus 1.0
Come interfacciare periferica twain
Ubuntu - aggiornare free pascal e lazarus
fpcup: installazioni parallele di lazarus e fpc
Free Pascal e Lazarus sul Raspberry Pi
Cifratura: breve guida all'uso dell'algoritmo BlowFish con lazarus e free pascal.
Creare un server multithread
guida all'installazione di fpc trunk da subversion in linux gentoo
Indice
DB concetti fondamentali e connessioni standard
Advanced Record Syntax
DB concetti fondamentali e DBGrid
DB concetti fondamentali e TDBEdit, TDBMemo e TDBText
Advanced Record Syntax: un esempio pratico
Superclasse form base per programmi gestionali (e non)
Superclasse form base per programmi gestionali (e non) #2 - log, exception call stack, application toolbox
Superclasse form base per programmi gestionali (e non) #3 - traduzione delle form
Superclasse form base per programmi gestionali (e non) #4 - wait animation
Un dialog per la connessione al database:TfmSimpleDbConnectionDialog
Installare lazarus su mac osx sierra
immagine docker per lavorare con lazarus e free pascal
TDD o Test-Driven Development
Benvenuto! Effettua l'accesso oppure registrati.
Maggio 16, 2024, 10:03:00 pm

Inserisci il nome utente, la password e la durata della sessione.

742 Visitatori, 0 Utenti

Post recenti

Pagine: [1] 2 3 ... 10
1
Generale / Re:un blog?
« Ultimo post da nomorelogic il Oggi alle 06:42:11 pm »
Ciao a tutti

per chi fosse interessato all'autenticazione a 2 fattori con Lazarus / Free Pascal, ho scritto un tutorial nel blog.

https://blog.lazaruspascal.it/2024/05/16/autenticazione-2fa/

C'è allegato anche il progetto, è minimale, spero venga compilato da tutti senza problemi.
Se ci sono svarioni, fate pure sapere.  :)

Spero sia utile
nomorelogic
2
Generale / Re:parametri passati per riferimento
« Ultimo post da petrusic il Oggi alle 05:16:17 pm »
Ho trovato il conflitto di dichiarazioni.

Non si vede nel codice che ho postato, perchè veniva scatenato dalla dichiarazione riportata nelle procedura chiamata:
Codice: [Seleziona]
procedure CancMovvFinIniAnno(tbIDMovim: String; nomeTbDB, nomeCampoID: String);  <-- prima

procedure CancMovvFinIniAnno(tbIDMovim: array of String; nomeTbDB, nomeCampoID: String);  <-- dopo

Sostituendo la prima riga con la seconda, la segnalazione è scomparsa.

Grazie, comunque. ;)
3
Generale / Re:parametri passati per riferimento
« Ultimo post da DragoRosso il Oggi alle 04:58:28 pm »
Prova così:
Codice: [Seleziona]
type

  { TForm1 }

  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
     procedure Cancella(elenco: array of string);
  public

  end;

var
  Form1: TForm1;

implementation

{$R *.lfm}

var prova: array of string;

{ TForm1 }

procedure TForm1.Cancella(elenco: array of string);
var ID: string;
begin
  for ID in elenco do
   begin
     ///CANCELLA IL RECORD QUI
   end;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  SetLength(prova, 10);
  ///RIEMPI L'ARRAY
  ///.............
  //Cchiama la canecllazione
  Cancella(prova);
  ///ELIMINA l'ARRAY
  SetLength(prova, 0);
end;

end.                           
4
Generale / [Risolto] parametri passati per riferimento
« Ultimo post da petrusic il Oggi alle 03:38:08 pm »
Dovrei richiamare una procedura alla quale passare un array contenente gli ID dei record di Database da eliminare.
Di fronte a tale prospettiva, ho pensato di passare alla procedura che dovrà occuparsi dell'eliminazione concreta dei record interessati, tutti i codici ID da cancellare dentro una variabile di tipo array. Gli array, come meglio chiarito qui, sono passati per riferimento.

Prendendo forza da ciò, ho proceduto a preparare il codice necessario:
Codice: [Seleziona]
var
 . . .
 striCodId2Canc: String = '';

  tabSplit: TStringArray;
  tbEl: TstringArray;
  tbIDmovimgg: TstringArray;         
 . . .
sql:= 'SELECT movimgg.IdMovvgg AS IDMovimgg, partmovv.IdPartGlob AS IDpartmovv FROM movimgg, partmovv, piancont WHERE movimgg.DtCoMovgg = partmovv.DtCoPartGlob';
    sql:= sql + ' AND movimgg.OraSolMovgg = partmovv.OraSolPartGlob AND movimgg.DtCoMovgg = ' + Form9.dataFin + ' AND movimgg.OraSolMovgg >= 235000 AND movimgg.OraSolMovgg <= 235959';
    sql:= sql + ' AND movimgg.CoVocMovvgg = piancont.NumVoce AND piancont.ContrPartSiNo = "Q" ORDER BY movimgg.NuProMovvgg, movimgg.CoVocMovvgg';
    striCodId2Canc:= PreparaCodIdCanc(sql); 
 . . .
    tabSplit:= striCodId2Canc.Split(chr(13));
    striCodIDmovimgg:= tabSplit[0];     // cioè tutti i codici ID della tabella di DB movimgg
    tbEl:= striCodIDmovimgg.Split(chr(9));
    setLength(tbIDmovimgg, Length(tbEl));
    for i:= 0 to (Length(tbEl) - 1) do
    begin
      tbIDmovimgg[i]:= tbEl[i];
    end;                                       
    CancMovvFinIniAnno(tbIDmovimgg, 'movimgg', 'IdMovvgg');      //  riga 4036
 . . .

Il Compilatore però non è però d'accordo con le mie assegnazioni perchè mi segnala il seguente errore:
Citazione
frm9.pas(4036,37) Error: Incompatible type for arg no. 1: Got "TStringArray", expected "AnsiString"

Ho provato a modificare l'array da "TStringArray" a "AnsiString", ma non ci sono riuscito per chè un tipo di array ansistring non è assegnabile (l'unico che ho trovato è "TAnsiStringBuilder").

Non capisco perchè non posso assegnare un array TStringArray. Pensavo ad un conflitto di assegnazioni nelle variabili dichiarate, ma non ho trovato niente. Non immagino perciò come potere procedere
5
Databases / Re:dbf
« Ultimo post da antonio63 il Maggio 12, 2024, 07:45:56 pm »
ti ringrazio
6
Databases / Re:dbf
« Ultimo post da bonmario il Maggio 12, 2024, 06:34:45 pm »
si fino a 10000 dati tutto sommato va bene .va in out of memory se clicchi piu volte per riordino.ho provato a creare 30000 record e da out of memory subito

Ciao,
usavo i DBF in un vecchio progetto, ormai in disuso da almeno 5 anni.
Se non ricordo male, potevi definire più chiavi, e quindi ordinamenti, e passare da una all'altra in maniera abbastanza semplice.

P.S. Allego un manualetto che avevo trovato non ricordo dove. Se lo apri e cerchi "IndexName", è quello di cui sto parlando.
P.P.S. Io lo usavo per cambiare l'ordinamento, e poi il DBF lo leggevo e la cosa funzionava, ma non lo mostravo a video con una DBGrid, quindi non so per certo se funziona o meno anche con quello

Ciao, Mario
7
Databases / Re:dbf
« Ultimo post da antonio63 il Maggio 12, 2024, 05:12:14 pm »
ti allego codice
8
Databases / Re:dbf
« Ultimo post da antonio63 il Maggio 12, 2024, 04:23:57 pm »
si fino a 10000 dati tutto sommato va bene .va in out of memory se clicchi piu volte per riordino.ho provato a creare 30000 record e da out of memory subito
9
Databases / Re:dbf
« Ultimo post da DragoRosso il Maggio 12, 2024, 02:30:24 pm »
se posso volevo anche chiedere non essendo possibile almeno da quanto ne so col dbf fare delle query tipo order by cognome per un riordino io ho caricato dbf in bufdataset e da li ho a seconda della colonna cliccata ho riordinato.pero se faccio piu riordini oppure carico abbastanza dati mi esce out of memory.

Qui non riesco ad aiutarti, non uso dbf e nemmeno database non SQL (che non supportano"ORDER BY"). Posso solo dirti che se compare quell'errore è probabile che tu stia usando dei buffer ad allocazione dinamica (size variabile) che non vengono correttamente allocati (o liberati) oppure che ci sia un limite con le strutture DBF (penso che Lazarus sia uno degli ultimi linguaggi a supportare dbf direttamente).

Un'altra possibilità è che tu stia sviluppando una applicazione a 32 bit che esaurisca effettivamente la memoria (però a meno che tu non abbia decina di migliaia di record ne dubito).

Qualcuno del forum, se ha già approcciato queste problematiche, forse potrebbe aiutarti.

Ciao

P.S.: se riporti parte del codice e dove viene generato l'errore magari ci si può ragionare.
10
Databases / Re:dbf
« Ultimo post da antonio63 il Maggio 12, 2024, 08:38:29 am »
se posso volevo anche chiedere non essendo possibile almeno da quanto ne so col dbf fare delle query tipo order by cognome per un riordino io ho caricato dbf in bufdataset e da li ho a seconda della colonna cliccata ho riordinato.pero se faccio piu riordini oppure carico abbastanza dati mi esce out of memory.
Pagine: [1] 2 3 ... 10

Recenti

How To

Utenti
Stats
  • Post in totale: 18823
  • Topic in totale: 2242
  • Online Today: 743
  • Online Ever: 900
  • (Gennaio 21, 2020, 08:17:49 pm)
Utenti Online
Users: 0
Guests: 742
Total: 742

Disclaimer:

Questo blog non rappresenta una testata giornalistica poiché viene aggiornato senza alcuna periodicità. Non può pertanto considerarsi un prodotto editoriale ai sensi della legge n. 62/2001.