Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione
Abbiamo provato per diverse settimane il nuovo Magic V5 di HONOR, uno smartphone pieghevole che ci ha davvero stupito. Il device è il più sottile (solo 4.1mm) ma non gli manca praticamente nulla. Potenza garantita dallo Snapdragon 8 Elite, fotocamere di ottima qualità e batteria in silicio-carbonio che garantisce un'ottima autonomia. E il Prezzo? Vi diciamo tutto nella nostra recensione completa.
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro)
Google Pixel 10 Pro XL è il top di gamma della serie Pixel, presentando un ampio display Super Actua da 6.8 pollici insieme alle novità della serie, fra cui la ricarica wireless magnetica Pixelsnap e le nuove funzionalità AI avanzate. Il comparto fotografico include un sistema a tripla fotocamera con zoom Pro Res fino a 100x, mentre il processore Tensor G5 con 16GB di RAM garantisce prestazioni percepite molto elevate su Android.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-03-2010, 09:09   #1
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Macro VBA Microsoft Excel

Buongiorno a tutti.
Tempo fa o creato una macro per excel per gestire delle consegne in base alle zone di consegna.
Facendo delle prove ho notato che la macro gira abbastanza bene però volevo tutto sommato far controllare il codice in quanto è la prima grande macro che scrivo. Se qualcuno fosse disposto ad a controllare i codici che ho scritto posso inoltrarvi i dettagli.
Vi comunico preventivamente che il ragionamento di funzionamento è abbastanza complesso e non vorrei farvi perdere tempo inutilmente.
Vi ringrazio anticipatamente.
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 09:30   #2
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Dipende, quante righe di codice sono ?
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 10:41   #3
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Dipende, quante righe di codice sono ?
Sono diverse righe di codice...Le devo postare per dare almeno un'idea??

Ultima modifica di ciullo87 : 22-03-2010 alle 14:10.
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 22:54   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da ciullo87 Guarda i messaggi
Sono diverse righe di codice...Le devo postare per dare almeno un'idea??
Da quanto ho capito il tuo codice funziona. Il rischio è di postare un fiume di codice che per chi legge ed è estraneo al tuo progetto non significa molto. Inoltre chi vuole rispondere dovrà costruirsi un WorkBook adatto per poterlo testare... La vedo dura.
Il mio consiglio è di postare solo le parti su cui nutri dubbi, ovviamente corredate da commenti significativi...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 23-03-2010, 07:41   #5
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Da quanto ho capito il tuo codice funziona. Il rischio è di postare un fiume di codice che per chi legge ed è estraneo al tuo progetto non significa molto. Inoltre chi vuole rispondere dovrà costruirsi un WorkBook adatto per poterlo testare... La vedo dura.
Il mio consiglio è di postare solo le parti su cui nutri dubbi, ovviamente corredate da commenti significativi...
Esatto...
Quelli che ho io sono dei dubbi sull'insieme del codice...Che possa essere scritto in modo migliore e che la procedura possa essere più veloce...Posterò in seguito parte di codice che forse potrebbe essere migliorata...Grazie per il momento dell'attenzione...
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 23-03-2010, 16:28   #6
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Quote:
Originariamente inviato da ciullo87 Guarda i messaggi
Esatto...
Quelli che ho io sono dei dubbi sull'insieme del codice...Che possa essere scritto in modo migliore e che la procedura possa essere più veloce...Posterò in seguito parte di codice che forse potrebbe essere migliorata...Grazie per il momento dell'attenzione...
Vi posto del codice per il caricamento di una list box all'apertura di un form.
Codice:
Private Sub UserForm_Activate()
Dim CL As Object
Dim frazione As String, nota1 As String, nota2 As String, comune As String, zona As String
Dim n As Integer
    ListaZona.Clear
    n = 0
    ListaZona.ColumnWidths = 90
    For Each CL In Worksheets("Zone_list").Range("A2:A14")
        ListaZona.AddItem CL.Value
        frazione = CL.Offset(0, 1).Value
        nota1 = CL.Offset(0, 8).Value
        nota2 = CL.Offset(0, 9).Value
        comune = CL.Offset(0, 2).Value
        zona = CL.Offset(0, 7).Value
        ListaZona.List(n, 1) = frazione
        ListaZona.List(n, 2) = nota1
        ListaZona.List(n, 3) = nota2
        ListaZona.List(n, 4) = comune
        ListaZona.List(n, 5) = zona
        n = n + 1
    Next
    If ListaZona.ListCount > 0 Then
        ListaZona.ListIndex = 0
    Else
        Note1.Caption = ""
        Note2.Caption = ""
        LabelComune.Caption = ""
        LabelZona.Caption = ""
    End If
End Sub
Di seguito invece la valorizzazione della listbox in base al valore inserito in una textbox. Funziona tutto solo che mi va a scatti la valorizzazione della listbox (forse ci sono troppe righe). Si può fare qualcosa?
Codice:
Private Sub TestoRicerca_Change()
Dim testodacercare As String
Dim CL As Object
Dim a As String, b As String, c As String, d As String, e As String
Dim frazione As String, nota1 As String, nota2 As String, comune As String, zona As String
Dim n As Integer
Dim colonna As Integer
    testodacercare = TestoRicerca.Value
    If testodacercare = "" Then
        Exit Sub
    End If
    
    ListaZona.Clear
    n = 0
    ListaZona.ColumnWidths = 90
    For Each CL In Worksheets("Zone").Range("A2:B1320")
        If CL.Value Like "*" & testodacercare & "*" Then
            colonna = CL.Column
            If colonna = 1 Then
                ListaZona.AddItem CL.Value
                frazione = CL.Offset(0, 1).Value
                nota1 = CL.Offset(0, 8).Value
                nota2 = CL.Offset(0, 9).Value
                comune = CL.Offset(0, 2).Value
                zona = CL.Offset(0, 7).Value
            End If
            If colonna = 2 Then
                ListaZona.AddItem CL.Offset(0, -1).Value
                frazione = CL.Value
                nota1 = CL.Offset(0, 7).Value
                nota2 = CL.Offset(0, 8).Value
                comune = CL.Offset(0, 1).Value
                zona = CL.Offset(0, 6).Value
            End If
            ListaZona.List(n, 1) = frazione
            ListaZona.List(n, 2) = nota1
            ListaZona.List(n, 3) = nota2
            ListaZona.List(n, 4) = comune
            ListaZona.List(n, 5) = zona
            n = n + 1
        End If
    Next
    If ListaZona.ListCount > 0 Then
        ListaZona.ListIndex = 0
    Else
        Note1.Caption = ""
        Note2.Caption = ""
        LabelComune.Caption = ""
        LabelZona.Caption = ""
    End If
End Sub
Spero sia tutto chiaro (non ho inserito nessun commento perchè mi sembra molto semplice come codice). Grazie mille dell'attenzione.
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 24-03-2010, 19:43   #7
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Non ho ben chiaro cosa intendi per "va a scatti la valorizzazione della listbox". In ogni caso puoi trarre beneficio nel filling di controlli particolarmente onerosi ( a quanto vedo riempi una ListBox su più colonne con oltre un migliaio di righe... ) sospendendo temporaneamente l'aggiornamentro grafico dell'applicazione e ripristinandolo quando il filling è terminato. Ad es.:

Codice:
    Application.ScreenUpdating = False
    
    '...
    'Fill Listbox
    '...
    
    Application.ScreenUpdating = True
Per il resto, personalmente non amo l'uso massiccio degli Offset...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2010, 09:02   #8
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Non ho ben chiaro cosa intendi per "va a scatti la valorizzazione della listbox". In ogni caso puoi trarre beneficio nel filling di controlli particolarmente onerosi ( a quanto vedo riempi una ListBox su più colonne con oltre un migliaio di righe... ) sospendendo temporaneamente l'aggiornamentro grafico dell'applicazione e ripristinandolo quando il filling è terminato. Ad es.:

Codice:
    Application.ScreenUpdating = False
    
    '...
    'Fill Listbox
    '...
    
    Application.ScreenUpdating = True
Per il resto, personalmente non amo l'uso massiccio degli Offset...
Grazie mille...
Ieri ho modificato leggermente il caricamento...
La colonna "A" contiene numeri (CAP delle città) mentre la colonna "B" testo (le frazioni da cercare) così ho usato la funzione IsNumeric e ora ho aggiunto le istruzioni che mi hai detto...
Già meglio...Purtroppo sono tante righe da controllare...
Grazie...
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2010, 13:31   #9
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da ciullo87 Guarda i messaggi
Grazie mille...
Ieri ho modificato leggermente il caricamento...
La colonna "A" contiene numeri (CAP delle città) mentre la colonna "B" testo (le frazioni da cercare) così ho usato la funzione IsNumeric e ora ho aggiunto le istruzioni che mi hai detto...
Già meglio...Purtroppo sono tante righe da controllare...
Grazie...
Ma non è tutto, ovviamente. Se la ListBox MultiColonna è destinata ad esempio a rappresentare valori presenti su un Foglio in formato tabellare, è superfluo, e inoltre lento, caricare ogni singola Cella facendo uso massiccio di .AddItem e Offset. Si può caricare l'intera tabella dati in modo molto più elegante, facendo uso della proprietà RowSource.
Esempio > tabella dati su Foglio1 "A1:C30" :

Codice:
    Application.ScreenUpdating = False
    With ListBox1
        .ColumnHeads = True
        .BoundColumn = 1
        .ColumnCount = 3
        .ColumnWidths = "50;100;100"
        .RowSource = "Foglio1!A1:C30"
        .ListStyle = fmListStyleOption
        .ListIndex = 0
    End With
    Application.ScreenUpdating = True
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2010, 14:31   #10
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Ma non è tutto, ovviamente. Se la ListBox MultiColonna è destinata ad esempio a rappresentare valori presenti su un Foglio in formato tabellare, è superfluo, e inoltre lento, caricare ogni singola Cella facendo uso massiccio di .AddItem e Offset. Si può caricare l'intera tabella dati in modo molto più elegante, facendo uso della proprietà RowSource.
Esempio > tabella dati su Foglio1 "A1:C30" :

Codice:
    Application.ScreenUpdating = False
    With ListBox1
        .ColumnHeads = True
        .BoundColumn = 1
        .ColumnCount = 3
        .ColumnWidths = "50;100;100"
        .RowSource = "Foglio1!A1:C30"
        .ListStyle = fmListStyleOption
        .ListIndex = 0
    End With
    Application.ScreenUpdating = True
Scusa ma forse non ho specificato che la listbox deve variare in base al valore che viene inserito (in pratica ogni digitazione deve variare il contenuto della listbox).
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2010, 15:12   #11
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da ciullo87 Guarda i messaggi
Scusa ma forse non ho specificato che la listbox deve variare in base al valore che viene inserito (in pratica ogni digitazione deve variare il contenuto della listbox).
Non era in merito al tuo codice. Solo un consiglio di massima...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 25-03-2010, 16:26   #12
ciullo87
Junior Member
 
Iscritto dal: Jun 2008
Messaggi: 16
Quote:
Originariamente inviato da MarcoGG Guarda i messaggi
Non era in merito al tuo codice. Solo un consiglio di massima...
Scusa non avevo capito...Ti ringrazio del consiglio...Molto gentile...
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
Lenovo IdeaPad Slim 3: un notebook Snapdragon X economico Lenovo IdeaPad Slim 3: un notebook Snapdragon X ...
Recensione OnePlus Watch 3 43mm: lo smartwatch che mancava per i polsi più piccoli Recensione OnePlus Watch 3 43mm: lo smartwatch c...
HUAWEI MatePad 11.5 2025, con schermo op...
Scheda video MSI RTX 5060 Ti in offerta ...
Gli incentivi ritardano, le vendite fren...
Accordo LG–Octopus Energy: pompe di calo...
12 articoli, da 9,94€ a 59,99€ su Amazon...
Robot aspirapolvere super potente a un p...
Dopo un mese dal lancio, Samsung si rico...
Smartwatch in super offerta su Amazon: C...
Offerta Amazon sugli Oral-B iO: due spaz...
iPhone 17, gli utenti vogliono il Pro e ...
A Milano il traffico aumenta, la propost...
3 SSD top in offerta su Amazon: con ques...
OPPO annuncia la nuova Serie Reno14 in I...
Rayman tornerà: arriva la conferm...
Stretta su YouTube Premium Family: ecco ...
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: 11:48.


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