Torna indietro   Hardware Upgrade Forum > Software > Programmi e Utility

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-11-2007, 20: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, 09: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, 11: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, 11: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, 11: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, 16: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, 16: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, 17: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, 17: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, 17: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, 18: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, 18: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, 20: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, 09: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


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Due scope elettriche super accessoriate ...
Intel perde un altro pezzo da novanta: a...
Scende al prezzo impossibile di 149€ il ...
SK hynix svela la mostruosa HBM4, la mem...
ECOVACS non si ferma più e conqui...
Da non credere: crolla a 899€ MacBook Ai...
ASUS ROG porta in Italia una nuova tasti...
Samsung Galaxy S26 Ultra: brutte notizie...
Cos'è RSL, il nuovo standard che ...
Nissan Micra EV: da 29.500 a oltre 36.00...
Processo Microsoft-ValueLicensing: cosa ...
L'edizione limitata più ambita da...
Lo sviluppatore di MSI Afterburner svela...
Quando l'AI diventa maestro: così...
Sony WH-1000XM6 già scontate su A...
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:58.


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