Torna indietro   Hardware Upgrade Forum > Software > Programmi e Utility

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-11-2007, 21:01   #1
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
[excel] aggiornamento automatico conteggi su file generato al volo

Ciao a tutti. Spiego velocemente il mio problema.
Ho un file di excel che viene creato al volo con vba da una query di access.

Dopo aver riportato nel foglio tutto il recordset di access, accodo ai record alcuni campi calcolati riepilogativi utilizzando la funzione conta.se in questo modo

valore1 = xlApp.CountIf(xlSheet.Range(intervallo), "valore1")
valore2 = xlApp.CountIf(xlSheet.Range(intervallo), "valore2")

Ovviamente se elimino ad esempio una riga nel foglio creato, la funzione conta.se non si aggiorna automaticamente perchè il valore è già stato calcolato.
Mi chiedevo quindi se esistesse un modo per ovviare a questo problema.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 10:27   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da john_revelator Guarda i messaggi
valore1 = xlApp.CountIf(xlSheet.Range(intervallo), "valore1")
valore2 = xlApp.CountIf(xlSheet.Range(intervallo), "valore2")

Ovviamente se elimino ad esempio una riga nel foglio creato, la funzione conta.se non si aggiorna automaticamente perchè il valore è già stato calcolato.
Mi chiedevo quindi se esistesse un modo per ovviare a questo problema.
In questo modo fai calcolare il tutto una volta sola, durante la creazione VBA del nuovo Sheet Excel, facendo eseguire ad Access una macro di Excel... Un po' tortuoso... E ovviamente nel Foglio ti ritrovi il risultato della Fx, e non la funzione stessa.

Io farei così :

1. Creo una variabile prima dell'esportazione del recordset, che contiene il RecordCount. Questo serve per "costruire" la seguente funzione.
Poniamo che questa variabile si chiami "NUM".

2. Sul foglio appena creato fai inserire da Access la formula in questo modo :

Range("A" & (NUM + 1)).FormulaR1C1 = "=COUNTIF(R[-" & NUM & "]C:R[-1]C,""11"")"
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 12:13   #3
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Ti ringrazio, sei stato molto gentile (speravo proprio in una tua risposta ).
Stasera cercherò di mettere in pratica i tuoi consigli, eventualmente tornerò a chiedere.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 12:22   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da john_revelator Guarda i messaggi
Ti ringrazio, sei stato molto gentile (speravo proprio in una tua risposta ).
Stasera cercherò di mettere in pratica i tuoi consigli, eventualmente tornerò a chiedere.
Magari posta uno dei tuoi file-tipo Excel generati da Access... Così faccio prima...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 12:51   #5
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Magari posta uno dei tuoi file-tipo Excel generati da Access... Così faccio prima...
Grazie, gentilissimo.
Prima ci sbatto la testa da solo, se avrò problemi saprò di poter contare sul tuo aiuto.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 17:04   #6
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Purtroppo devo chiedere il tuo aiuto. Mi sto incasinando non poco.
Allora, per il momento sto provando il tutto su una query "statica". Penso che una volta capito il meccanismo riuscirò ad adattarlo alle mie query create con QueryDef.

Supponendo che il mio foglio generato sia così

Codice:
            A    B     C     D
1       QUA ANDRA' IL TITOLO 
2         ID  NOME COGNOME TIPO
3        ...    ...     ...    lavorativo
4                              formativo
5                              lavorativo
6
...
17      ...    ...     ...     formativo
quindi con la prima riga che conterrà l'intestazione creata dinamicamente, la seconda riga che conterrà le intestazioni di colonna e i record contenuti nell'intervallo a3:d17, a me interessa che ad esempio appaia nella cella d19 il totale di lavorativo, nella cella d20 il totale di formativo eccetera (sono in tutto quattro tipologie).

Ho usato una variabile per il conteggio dei record in questo modo

Record = objRST.RecordCount

la usavo già prima anche con la mia soluzione casereccia.
Stavo provando ad adattare la tua formula alla mia situazione ma invano.

Uno dei vari tentativi è stato questo

lavDin = Range("D" & (Record + 2)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""lavorativo"")"
xlSheet.Cells(Record + 10, 4).Value = lavDin

ma mi restituisce FALSO.

Grazie per la pazienza.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 17:29   #7
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Ho fatto qualche piccolo progresso.

xlSheet.Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""lavorativo"")"

Se scrivo così nella cella sottostante l'ultimo record, viene visualizzato il numero corretto con la funzione conta.se e anche eliminando le righe il conteggio viene aggiornato nel modo corretto.

Però come detto a me serve applicare la funzione quattro volte.
Se scrivo così ad esempio, estendendo la conta a due tipologie

xlSheet.Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""lavorativo"")"
xlSheet.Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""formativo"")"

la conta di lavorativo non appare ed esce solo quella di formativo.
Avrei anche un'altra domanda. I conteggi devono trovarsi per forza a partire dalla cella immediatamente sottostante l'ultimo record oppure no?
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 18:36   #8
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Sto ancora provando. Se scrivo

xlSheet.Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""lavorativo"")"
xlSheet.Range("D" & (Record + 3)).Offset(1, 0).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""formativo"")"
xlSheet.Range("D" & (Record + 3)).Offset(2, 0).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""avvio impresa"")"
xlSheet.Range("D" & (Record + 3)).Offset(3, 0).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""altro"")"

i valori appaiono tutti e quattro ma non fanno riferimento allo stesso intervallo (nel mio esempio d3:d17) ma diventano d4:d18, d5:d19 eccetera. Come faccio a bloccare il range su cui deve agire ?
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 18:48   #9
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da john_revelator Guarda i messaggi
Però come detto a me serve applicare la funzione quattro volte.
Se scrivo così ad esempio, estendendo la conta a due tipologie

xlSheet.Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""lavorativo"")"
xlSheet.Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & Record & "]C:R[-1]C,""formativo"")"

la conta di lavorativo non appare ed esce solo quella di formativo.
Avrei anche un'altra domanda. I conteggi devono trovarsi per forza a partire dalla cella immediatamente sottostante l'ultimo record oppure no?
La tua seconda domanda è chiaramente legata alla prima.
Se tu applichi contemporaneamente le due linee di codice che hai postato, la prima formula verrà inserita, e subito sovrascritta dalla seconda.
Puoi mettere il risultato della seconda formula in una cella subito sotto, semplicemente incrementando di 1 quel "(Record+3)".
Inoltre c'è un altro errore nel tuo codice, perchè se "stacchi" di 3 celle rispetto all'ultima che contiene un record, il TUTTO sarà :

Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & (Record + 3 - 1) & "]C:R[-3]C,""11"")"

Range("D" & (Record + 4)).FormulaR1C1 = "=COUNTIF(R[-" & (Record + 4 - 1) & "]C:R[-4]C,""11"")"


E così via...
Prova...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 18:50   #10
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Ho già risposto anche al tuo ultimo post...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 19:00   #11
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & (Record + 3 - 1) & "]C:R[-3]C,""11"")"

Range("D" & (Record + 4)).FormulaR1C1 = "=COUNTIF(R[-" & (Record + 4 - 1) & "]C:R[-4]C,""11"")"
Scusa, c'è un "11" che non c'entra un fico...
L' avevo usato io per fare un test... Mettici il TUO valore ovviamente... :

Range("D" & (Record + 3)).FormulaR1C1 = "=COUNTIF(R[-" & (Record + 3 - 1) & "]C:R[-3]C,""TUO_VALORE"")"

Range("D" & (Record + 4)).FormulaR1C1 = "=COUNTIF(R[-" & (Record + 4 - 1) & "]C:R[-4]C,""TUO_VALORE"")"
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 19:23   #12
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Sei un grande. Adesso funziona tutto. Grazie mille

Ho un'ultimissima domanda e poi non ti stresso più .
Mi servirebbe sotto i 4 valori che anche il totale venisse generato automaticamente.

Sto facendo un pò di prove ma sicuramente sbaglio la sintassi.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 27-11-2007, 21:48   #13
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Così funziona

xlSheet.Range("D" & (Record + 7)).Formula = "=SUM(D" & Record + 3 & ":D" & Record + 6 & ")"

Mi hai risolto un grossissimo problema.
Grazie ancora di tutto e complimenti. :)
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 28-11-2007, 10:01   #14
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Wi-Fi 8 secondo Intel: la nuova era del ...
MediaWorld e il caso degli iPad Air vend...
ESA: rilevati 40 mila asteroidi vicino a...
La batteria salva fabbriche di EQORE ott...
SpaceX Starship: iniziati i test della t...
Datacenter IA nello spazio entro 5 anni,...
Telescopio spaziale James Webb: rilevato...
Ericsson Mobility Report: nel 2025 il 5G...
PLAI DEMO DAY: si chiude il secondo cicl...
Google rilascia Nano Banana Pro: il nuov...
ChatGPT si rinnova ancora: disponibile l...
Ring lancia super sconti di Black Friday...
Black Friday 2025: 450 euro di sconto su...
Tutte le offerte Blink in un unico posto...
OpenAI e Foxconn uniscono le forze per r...
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: 08:25.


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