Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione
OPPO ha portato in Italia, dal 1° luglio 2026, Reno16 Pro: display AMOLED da 6,32 pollici a 144Hz, tripla fotocamera con sensore principale da 200 megapixel, chip Dimensity 8550 Super e batteria da 6000mAh, al prezzo di lancio di 899 euro. Lo abbiamo provato per due settimane insieme al nuovo accessorio Bubble, per capire se la formula compatta della serie regge ancora di fronte a un listino da 1099 euro
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-02-2004, 12:08   #1
RunDLL
Senior Member
 
L'Avatar di RunDLL
 
Iscritto dal: Jan 2004
Città: Perugia
Messaggi: 326
Problemi di calcolo con VBA

Ciao a trutti e grazie per leggere il mio problema: ho cercato di fare un piccolo programmino in VBA , semplice nulla di che, praticamente in una Form ho inserito 3 optionbutton che se cliccati mi cambiano la caption di un commandbutton. Poi ho inserito 6 textbox dove nella sesta mi dovrebbe dare il risultato di alcuni calcoli rendendo i dati inseriti nella altre textbox. In poche parole volevo creare un programmino che inserendo i valori nelle textbox mi calcolassero l'area del cerchio, del quadrato e del triangolo. Ho impostato che al click di ogni optionbutton mi cambiasse la caption del commandbutton perchè al verificarsi della diversa caption mi facesse i calcoli di una o dell'altra forma, poi ho scritto quanto seghe nell'evento click del commandbutton:

Private Sub Command1_Click()
If Command1.Caption = "Area triangolo" And Text1.Text = "" And Text2.Text = "" Then
MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"
Else
Text6.Text = Text1.Text * Text2.Text / 2
End If
If Command1.Caption = "Area quadrato" And Text3.Text = "" And Text4.Text = "" Then
MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"
Else
Text6.Text = Text3.Text * Text4.Text
End If
If Command1.Caption = "Area cerchio" And Text5.Text = "" Then
MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"
Else
Text6.Text = (Text5.Text) ^ 2 * 3.14
End If
End Sub

Mi sembrerebbe tutto in regola se non che mi da errore "tipo non corrispondente" sia che lasci le textbox vuote che se ci metta dei valori.
Allora ho provato a dare queste istruzioni:
Private Sub Command1_Click()
If Command1.Caption = "Area triangolo" And Text1.Text <> "" And Text2.Text <> "" Then
Text6.Text = Text1.Text * Text2.Text / 2
Else
MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"
End If
If Command1.Caption = "Area quadrato" And Text3.Text <> "" And Text4.Text <> "" Then
Text6.Text = Text3.Text * Text4.Text
End If
If Command1.Caption = "Area cerchio" And Text5.Text <> "" Then
Text6.Text = (Text5.Text) ^ 2 * 3.14
End If
End Sub

Così funziona già molto meglio nel primo caso se non metto valori mi compare giustamente la msgbox che non ho inserito i valori se metto i valori mi fà il calcolo, quindi funziona perfettamente, ma negli altri due casi mi da la mgbox sia che metta i valori che se non li metto, il calcolo lo fà però comunque solo che compare questa msgbox sempre.
Qualcuno mi può aiutare a capire dove sbaglio?
Se non è tutto chiaro e credete sia necessario vi mando il file di excel dove l'ho creato, è comunque scaricabile subito da quà:
http://bluelightning.altervista.org/aree.zip
Grazie e tanti saluti
RunDLL è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2004, 13:19   #2
cisky
Member
 
L'Avatar di cisky
 
Iscritto dal: Aug 2001
Città: Gerenzano
Messaggi: 129
Il problema riguardo al fatto che ti compare il messaggio "tipo non corrispondente" è causato dal fatto che tu esegui delle operazioni con dei tipi stringa (Il testo delle textbox).
Dovresti invece utilizzare la funzione VAL per recuperare il valore numerico.

Il problema del MsgBox che compare sempre, semplicemente è causato dal fatto che la prima condizione IF .. THEN ... ELSE non è verificata nel caso di calcolo dell'area del quadrato o del cerchio e quindi verrà sempre eseguito il comando MSGBOX nel case else.

Mi spiego meglio

If Command1.Caption = "Area triangolo" And Text1.Text <> "" And Text2.Text <> "" Then

Se stai calcolando l'area del quadrato, la caption del command1 è "Area quadrato" e quindi la condizione IF non è verificata perciò viene eseguito il codice nella parte ELSE è cioè:

MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"


Il codice giusto è questo:

Codice:
Private Sub Command1_Click()

    If Command1.Caption = "Area triangolo" And Text1.Text <> "" And Text2.Text <> "" Then
        Text6.Text = Text1.Text * Text2.Text / 2
    ElseIf Command1.Caption = "Area quadrato" And Text3.Text <> "" And Text4.Text <> "" Then
        Text6.Text = Text3.Text * Text4.Text
    ElseIf Command1.Caption = "Area cerchio" And Text5.Text <> "" Then
        Text6.Text = (Text5.Text) ^ 2 * 3.14
    Else
        MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"
    End If
End Sub
Basarsi sul testo di un controllo non è una buona pratica di programmazione, dovresti utilizzare una variabile a livello di modulo (Magari un enum) che viene impostato quando selezioni un option Button

Esempio:

Codice:
' *** Da mettere nella parte di 'Dichiarazioni'
'
Private Enum ModalitaCalcoloEnum
    mcTriangolo = 0
    mcQuadrato
    mcCerchio
End Enum

Private m_eModalita         As ModalitaCalcoloEnum

' -------------------

Private Sub Command1_Click()
    
    Dim bDatiSet        As Boolean
    Dim nValore1        As Double
    Dim nValore2        As Double
    Dim nArea           As Double
    
    Select Case m_eModalita ' *** Impostata a livello di 'dichiarazioni'
        
        Case mcTriangolo
            nValore1 = Val(Text1.Text) > 0
            nValore2 = Val(Text2.Text) > 0
            
            bDatiSet = (nValore1 > 0 And nValore2 > 0)
            ' *** è meglio fare così =>   bDatiSet = IsNumeric(Text1.Text) AND IsNumeric(Text2.Text) ***
            nArea = nValore1 * nValore2 / 2
        
        Case mcQuadrato
            nValore1 = Val(Text3.Text) > 0
            nValore2 = Val(Text4.Text) > 0
            bDatiSet = (nValore1 > 0 And nValore2 > 0)
            nArea = nValore1 * nValore2
            
        Case mcCerchio
            nValore1 = Val(Text5.Text) > 0
            bDatiSet = (nValore1 > 0)
            nArea = nValore1 ^ 2 * 3.14
            
    End Select
       
    If bDatiSet Then
        Text6.Text = CStr(nArea)
    Else
        MsgBox "Inserisci i dati nei campi", vbCritical, "Dati mancanti"
    End If
       
End Sub
Ciao
__________________
E' quasi tutto relativo!
cisky è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2004, 14:21   #3
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
Re: Problemi di calcolo con VBA

Quote:
Originariamente inviato da RunDLL
Ciao a trutti e grazie per leggere il mio problema: ho cercato di fare un piccolo programmino in VBA , semplice nulla di che, praticamente
in una Form ho inserito
3 optionbutton che se cliccati mi cambiano la caption
di un commandbutton.
Poi ho inserito 6 textbox dove nella sesta mi dovrebbe dare il risultato di alcuni calcoli rendendo i dati inseriti
nella altre textbox.
In poche parole volevo creare un programmino che inserendo i valori nelle textbox
mi calcolassero l'area del cerchio,
del quadrato
e del triangolo.
Ho impostato che al click di ogni optionbutton
mi cambiasse la caption del commandbutton
perchè al verificarsi della diversa caption
mi facesse i calcoli di una o dell'altra forma,
poi ho scritto quanto seghe
nell'evento click del commandbutton:

....

a volte è tutto scritto: basta leggere.
a2000 è offline   Rispondi citando il messaggio o parte di esso
Old 05-02-2004, 14:31   #4
a2000
Bannato
 
L'Avatar di a2000
 
Iscritto dal: Jan 2001
Messaggi: 1976
comunque numero 51078 non ti preoccupare,
in effetti tutti prima di scopare fanno quanto seghe: è una giusta esercitazione.

e qualcuno anche dopo.
a2000 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Reno16 Pro: il compatto di OPPO punta su fotocamera da 200MP e il nuovo Bubble! La recensione Reno16 Pro: il compatto di OPPO punta su fotocam...
 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Anche T-Mobile abbandona VMware e migra ...
In Italia crescono gli investimenti nell...
Samsung combina IA e quantum computing p...
Anthropic ammette: Claude Code usa un ap...
L'IA costa sempre di più: AWS aum...
Google prepara il blocco delle app non v...
Amazfit aggiorna il Cheetah 2 Ultra: ric...
L'FAA apre ai voli commerciali supersoni...
Amazon ha già abbastanza satelliti per a...
A2A ed Equinix uniscono le forze per rec...
Apple ha creato la crisi delle memorie? ...
GPU subito in cambio di una quota dei ri...
Firefly Aerospace potrà lanciare ...
Intesa Sanpaolo sposta i sistemi IT core...
Visa, Mastercard e Coinbase lanciano Ope...
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: 19:29.


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