Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-03-2010, 10: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, 10: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, 11: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 15:10.
ciullo87 è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2010, 23: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, 08: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, 17: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, 20: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, 10: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, 14: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, 15: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, 16: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, 17: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


Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
NASA: l'equipaggio di Crew-11 rientrer&a...
CoopVoce lancia le sue prime offerte 5G:...
Rivoluzione The Elder Scrolls Online: un...
Lo strapotere cinese è evidente c...
GeForce RTX 6000: niente SUPER e attesa ...
Anche gli Stati Uniti puntano il dito co...
È cinese la prima (enorme) pala e...
A Pechino è record di giorni con ...
Lenovo al CES 2026: Qira, IA ambientale ...
Le sette startup italiane che ridefinisc...
Philips Hue SpatialAware: la configurazi...
Sport & Lifestyle: performance, dati...
Le novità HP al CES 2026 tra AI P...
Gigabyte propone OLED per tutti con lumi...
Musk contro OpenAI, la guerra arriva in ...
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: 00:57.


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