Novità

Per eccesso o per difetto

salvo50

Advanced Member >PLATINUM PLUS<
Ciao a Tutti!

Esiste una funzione che mi dà un risultato per eccesso o per difetto?

Grazie!
 
Come non detto, mi sono accorto che lo fà già automaticamente con < / > invece con l'altro < \ > toglie i decimali senza arrotondare per eccesso o per difetto, non ci avevo mai fatto caso.
 
ciao se necessario in ambito script si puo comunque scrivere una funzione che riceva il numero da arrotondare per difetto o per eccesso e che ce lo restituisca arrotondato..
 
Ciao LuigiB

Infatti io avevo iniziato a studiare dei passaggi per avere i numeri arrotondati per eccesso e difetto in attesa che qualcuno rispondesse al post, quando mi sono accorto che i risultati delle divisioni erano già arrotondati, quindi per le divisioni (secondo me) è già a posto così, invece per le moltiplicazioni, sarebbe comodo avere una funzione che faccia tutto in automatico, ma penso che succeda raramente di avere dei numeri con decimali in una moltiplicazione perchè bisogna già moltiplicare dei numeri decimali per avere dei decimali nel risultato.
 
Ultima modifica:
intendevo di scriverla nello script .. inoltre tutte le funzioi che uno si scrive da solo possono essere inserite in un file richiamabile da qualsiasi script e quindi si possono riusare.

comunque la funzione per come ho capito che ti serve eccola.... ciao

Codice:
Option Explicit
Sub Main
    Const vDec1 = 25.2
    Scrivi  "Il numero " & vDec1  & " arrotondato per difetto : " & Arrotonda (vDec1 ,False)
    Scrivi  "Il numero " & vDec1  & " arrotondato per eccesso : " & Arrotonda (vDec1 ,True)

    Const vDec2 = 25.8
    Scrivi  "Il numero " & vDec2  & " arrotondato per difetto : " & Arrotonda (vDec2 ,False)
    Scrivi  "Il numero " & vDec2  & " arrotondato per eccesso : " & Arrotonda (vDec2 ,True)

    Const vDec3 = 25
    Scrivi  "Il numero " & vDec3  & " arrotondato per difetto : " & Arrotonda (vDec3 ,False)
    Scrivi  "Il numero " & vDec3  & " arrotondato per eccesso : " & Arrotonda (vDec3 ,True)



End Sub
Function Arrotonda (n , bPerEccesso)
    ' se il numero è un intero non lo arrotonda
    If n  = CLng(n) Then
        Arrotonda = n
    Else
        If bPerEccesso Then
            Arrotonda = CLng(n+0.5)
        Else
            Arrotonda = CLng(n-0.5)


        End If
    End If

End Function

che da questo output

Codice:
Il numero 25,2 arrotondato per difetto : 25
Il numero 25,2 arrotondato per eccesso : 26
Il numero 25,8 arrotondato per difetto : 25
Il numero 25,8 arrotondato per eccesso : 26
Il numero 25 arrotondato per difetto : 25
Il numero 25 arrotondato per eccesso : 25
Codice:
 
Ultima modifica di un moderatore:

Ultima estrazione Lotto

  • Estrazione del lotto
    giovedì 21 maggio 2026
    Bari
    88
    65
    11
    87
    59
    Cagliari
    05
    64
    45
    80
    74
    Firenze
    37
    56
    25
    19
    36
    Genova
    29
    31
    90
    15
    17
    Milano
    73
    61
    45
    85
    48
    Napoli
    21
    85
    29
    48
    77
    Palermo
    40
    02
    66
    87
    51
    Roma
    23
    68
    57
    60
    26
    Torino
    44
    04
    76
    05
    57
    Venezia
    79
    86
    19
    29
    40
    Nazionale
    33
    54
    75
    39
    63
    Estrazione Simbolotto
    Milano
    27
    16
    30
    21
    26
Indietro
Alto