Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-10-2004, 14:09   #1
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
OLE e Borlan Builder

sto usando queso codice per aprire e chidere un foglio di excel ma all'uscita Excel mi rimane costantemente in memoria anche dopo la chiamata di Excel.OleFunction("Quit");

c'è un motivo ?

c'è qualcuno che conosce OLE ?

grazie 1000 in anticipo

Codice:
if (OpenDialog1->Execute()) //*.xls-Dateinamen + Pfad angeben
{

try
{

Variant Excel;
Excel = Variant::CreateObject("Excel.Application");
Excel.OlePropertyGet("ActiveWorkBook");

// Excel-Datei öffnen
Excel.OlePropertyGet("WorkBooks").OleFunction("Open", OpenDialog1->FileName);

//Excel.OlePropertySet("Visible", true); //Excel beim Arbeiten anzeigen, false = ausblenden

Variant Sheet;
Sheet=Excel.OlePropertyGet("ActiveSheet");
AnsiString Zelleninhalt = Sheet.OlePropertyGet("Cells", 1, 1).OlePropertyGet("Value");// Zeile 1, Spalte 1 auslesen

ShowMessage(Zelleninhalt);

ShowMessage("Excel wird jetzt wieder geschlossen");

Excel.OleFunction("Quit");
Excel = Unassigned;

}
catch(...){}

}
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 27-10-2004, 21:08   #2
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
possibile che utilizzo solo io queste, chiamiamole tecnologie strane di windows ?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2004, 13:31   #3
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
caspita che pigroni che siete.....

vi risulta che l'utilizzo di tecnologia OLE nei propri programmi abbia prestazioni scadenti ?

io con un codice simile a quello del primo post, impiego 20 secondi per trasferire dati da un foglio di Excel su file; possibile avere prestazioni così scadenti ???
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2004, 11:07   #4
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
up

se guardate il codice da me postato, osseverete che utilizza l'ole automation


parlando di compilatori:

io, per usare tali funzioni da "iniettare" dal BCB (Borland Builder C++) includo il seguente file:

#include <utilcls.h>

mi viene un dubbio

da tale file, è possibile risalire alle funzioni che sono implementate nel compilatore in mio possesso ?

a me durante la fase di compilazione non vengono generati errori, ne vedo solo in fase di esecuzione
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2004, 11:20   #5
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Lungi da me essere un guru di OLE, ma sei sicuro che questa
Quote:
Excel.OleFunction("Quit");
sia sufficiente a distruggere l'oggetto allocato in precedenza, e a rilasciare il reference? La riga successiva non credo che abbia effetto...
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2004, 11:25   #6
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
non sono una mago neppure io, difatti quella chiamata svolge malissimo il suo compito

Excel rimane ancora in memoria

tieni presente che quel codice è un esempio che ho trovato in rete e l'ho preso così com'è
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2004, 11:40   #7
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Non c'è un metodo "release" o simili?
Rimuovi anche l'assegnazione di Unassigned; può darsi che alla distruzione dell'oggetto variant, viene invocato il codice di rilascio automaticamente.
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2004, 12:44   #8
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
non esiste quanto dici.....

in rete si trovano esempi solo su siti francesi e cinesi o giapponesi

anche eliminando quello che tu hai detto non accade nulla

per questo ho iniziato a dubitare che il BCB che possiedo io, magari non implementa tutte le funzioni in quanto, la visualizzazione de messaggi di errore avviene solo dopo l'esecuzione del programma e non in fase di compilazione

se apro il task manager mi ritrovo costantemente Excel in esecuzione


Variant Excel;
Excel = Variant::CreateObject("Excel.Application");


negli esempi che si trovano in rete, con:

Excel.OleFunction("Quit")

dovrebbe venire rilasciato l'oggetto creato sopra, ma tale chiamata non sortisce l'effetto desiderato
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 18-11-2004, 21:08   #9
ilsensine
Senior Member
 
L'Avatar di ilsensine
 
Iscritto dal: Apr 2000
Città: Roma
Messaggi: 15625
Prova a cambiare tecnica...importa la tlb (type library) di Excel ed usa direttamente quella
Almeno puoi vedere i metodi supportati dai vari oggetti...
__________________
0: or %edi, %ecx; adc %eax, (%edx); popf; je 0b-22; pop %ebx; fadds 0x56(%ecx); lds 0x56(%ebx), %esp; mov %al, %al
andeqs pc, r1, #147456; blpl 0xff8dd280; ldrgtb r4, [r6, #-472]; addgt r5, r8, r3, ror #12
ilsensine è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2004, 07:27   #10
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
ho trovato OleView, ora ci guardo


grazie

Ultima modifica di misterx : 19-11-2004 alle 07:36.
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2004, 07:43   #11
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
è incomprensibile quello che si legge
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 21-11-2004, 16:29   #12
misterx
Senior Member
 
Iscritto dal: Apr 2001
Città: Milano
Messaggi: 3741
va bene, ho messo il tutto a posto con un trucco anche se il Quit funziona molto male, bah...

mi stavo chiedendo come ovviare al non multitask del programmetto sopra nel senso che: quando lo eseguo, durante la fase di apertura di Excel e del relativo foglio, il mio programma viene messo a tacere

durante l'esecuzione del mio programma per far capire all'utente che il tutto sta funzionando correttamente, ho implementato un piccolo orologio che purtroppo si ferma nel momento in cui inizia la fase di apertura di Excel e del relativo foglio

quando il controllo poi torna al mio programma, torna a funzionare

però quella pausa da veramente fastidio

c'è un modo per evitarla ?
misterx è offline   Rispondi citando il messaggio o parte di esso
Old 21-11-2004, 16:42   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Fai un thread

Che trucco hai usato ?
cionci è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Il riconoscimento facciale è un'a...
Un affare pazzesco, finché dura o...
Lava a 75°, è un 21.000Pa con...
iPhone 18 Pro: il componente che garanti...
DeepL alza il livello: con Voice-to-Voic...
Apple sta utilizzando sempre più ...
Il MacBook Neo vende tanto? Microsoft le...
AST SpaceMobile BlueBird 7: Blue Origin ...
È il momento migliore per comprar...
Svendita MacBook Pro: c'è il mode...
Oggi questa TV TCL QLED da 43 pollici co...
Il caricatore multiplo da 200W che va be...
Top 7 Amazon, il meglio del meglio di qu...
Spento lo strumento LECP della sonda spa...
Voyager Technologies ha siglato un accor...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 07:38.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v