Ancalagon
06-04-2010, 13:03
Mi trovo nella sittuazione di dover creare una macro per Excel in VBA, e vorrei capire quale sarebbe la
soluzione migliore da usare. Ho già crato una decina di macro e programmini, ma mai con una tale
quantità di dati su cui lavorare. Allora vediamo di chiarire spiegando da dove parto e cosa devo
ottenere.
CON COSA PARTO: (2 file)
Mi ritroverò con un file excel con questa struttura (3 colonne per minimo 900 righe):
1) file excel ARTICOLI (righe totali dalle 900 alle 1400)
CODICE ARTICOLO DESCRIZIONE ART. QUANTITà ART. A FINE MESE
X1213 PENNA A SFERA 15'200
Y0550 PENARELLI 10'900
....
....
SPIEGAZIONE:
Ogni CODICE ARTICOLO che trovo nell'elenco sopra citato, ha una propria DISTINTA. La distinta è un
elenco di COMPONENTI usati per creare l'articolo (es. DUE penne a sfera sono create da 2 molle, 10 ml
d'inchiostro, 2 corpi penna, 2 gommine anti-scivolo, ecc...). Spiegato questo vi dico subito che mi sono
già preparato un file excel con le varie distinte, come segue:
2) file excel DISTINTE (righe totali +6'000)
CODICE ART. COD. COMPONENTE DESCRIZ.COMP NR. COMP X CODICE
X1213 AB0123 MOLLA PENNA 1
X1213 ZB0124 ADESIVI MARCA 2
.....
.....
SPIEGAZIONE FILE DISTINTA:
Nel secondo file excel (che FORSE non useremo proprio) ho le DISTINTE (elenco componenti) dei vari
codici che vengono prototti. L'unico riferimento tra il primo file excel (giacenze a fine mese) ed il
secondo file excel (distinte deigli articoli) e la colonna CODICE ART. che ho inserito apposta
CODICE ART = codice articolo IDENTICO
COD. COMPONENTE = codice del componente usato per creare il CODICE ARTICOLO
DESCRIZ. COMP = semplicemente una stringa che descrive il nome del componente
NR. COMP X CODICE = è il numero che indica QUANTI componenti vengono usati per fare 1 ARTICOLO
es. per fare i penna si usa solo UNA molla. Per fare un calcolatore abbiamo bisogno
di 15 tasti (solo esempio)
COSA DEVO OTTENERE:
CODICE ART. DESCRIZ. PZ. FINE MESE COMP Qtà. COMP. USATA
X1213 PENNA 15'200 AB0123 15'200
X1213 PENNA 15'200 ZB0124 30'400
Quello che devo ottenere è una macro che mi moltiplichi la QUANTITà ART. (del primo file a 3 colonne)
per il NR. COMP X CODICE. Sul come fare i calcoli non ci sono problemi, è basilare, vorrei capire come
immagazzinare i dati delle distinte nella macro. Come detto sopra l'elenco delle distinte è superiore
alle 6'000 righe e solitamente (con dati di massimo 150 righe o simili) usavo il SELECT CASE per trovare
la corrispondenza tra il CODICE ART. e le distinte
Esempio di come facevo prima
1) la macro prendeva il codice seleziona e lo assegnava ad una variabile "COD"
2) la macro usava un SELECT CASE per capire che valore aveva la variabile "COD" e di conseguenza
assegnava ad altre variabili alcuni valori come "COLORE", "VARIANTE", SCATOLE"
Ma quando si parla di 6000 righe come mi conviene agire? Uso lo stesso sistema del SELECT CASE? Creo
degli arrey? Uso la macro per accedere al file excel DISTINTE per fare la ricerca?
soluzione migliore da usare. Ho già crato una decina di macro e programmini, ma mai con una tale
quantità di dati su cui lavorare. Allora vediamo di chiarire spiegando da dove parto e cosa devo
ottenere.
CON COSA PARTO: (2 file)
Mi ritroverò con un file excel con questa struttura (3 colonne per minimo 900 righe):
1) file excel ARTICOLI (righe totali dalle 900 alle 1400)
CODICE ARTICOLO DESCRIZIONE ART. QUANTITà ART. A FINE MESE
X1213 PENNA A SFERA 15'200
Y0550 PENARELLI 10'900
....
....
SPIEGAZIONE:
Ogni CODICE ARTICOLO che trovo nell'elenco sopra citato, ha una propria DISTINTA. La distinta è un
elenco di COMPONENTI usati per creare l'articolo (es. DUE penne a sfera sono create da 2 molle, 10 ml
d'inchiostro, 2 corpi penna, 2 gommine anti-scivolo, ecc...). Spiegato questo vi dico subito che mi sono
già preparato un file excel con le varie distinte, come segue:
2) file excel DISTINTE (righe totali +6'000)
CODICE ART. COD. COMPONENTE DESCRIZ.COMP NR. COMP X CODICE
X1213 AB0123 MOLLA PENNA 1
X1213 ZB0124 ADESIVI MARCA 2
.....
.....
SPIEGAZIONE FILE DISTINTA:
Nel secondo file excel (che FORSE non useremo proprio) ho le DISTINTE (elenco componenti) dei vari
codici che vengono prototti. L'unico riferimento tra il primo file excel (giacenze a fine mese) ed il
secondo file excel (distinte deigli articoli) e la colonna CODICE ART. che ho inserito apposta
CODICE ART = codice articolo IDENTICO
COD. COMPONENTE = codice del componente usato per creare il CODICE ARTICOLO
DESCRIZ. COMP = semplicemente una stringa che descrive il nome del componente
NR. COMP X CODICE = è il numero che indica QUANTI componenti vengono usati per fare 1 ARTICOLO
es. per fare i penna si usa solo UNA molla. Per fare un calcolatore abbiamo bisogno
di 15 tasti (solo esempio)
COSA DEVO OTTENERE:
CODICE ART. DESCRIZ. PZ. FINE MESE COMP Qtà. COMP. USATA
X1213 PENNA 15'200 AB0123 15'200
X1213 PENNA 15'200 ZB0124 30'400
Quello che devo ottenere è una macro che mi moltiplichi la QUANTITà ART. (del primo file a 3 colonne)
per il NR. COMP X CODICE. Sul come fare i calcoli non ci sono problemi, è basilare, vorrei capire come
immagazzinare i dati delle distinte nella macro. Come detto sopra l'elenco delle distinte è superiore
alle 6'000 righe e solitamente (con dati di massimo 150 righe o simili) usavo il SELECT CASE per trovare
la corrispondenza tra il CODICE ART. e le distinte
Esempio di come facevo prima
1) la macro prendeva il codice seleziona e lo assegnava ad una variabile "COD"
2) la macro usava un SELECT CASE per capire che valore aveva la variabile "COD" e di conseguenza
assegnava ad altre variabili alcuni valori come "COLORE", "VARIANTE", SCATOLE"
Ma quando si parla di 6000 righe come mi conviene agire? Uso lo stesso sistema del SELECT CASE? Creo
degli arrey? Uso la macro per accedere al file excel DISTINTE per fare la ricerca?