Funkcja FormatPercent [VBA]
Zwraca ciąg z formatowaniem liczb zastosowanym do wyrażenia liczbowego. Do zwróconego ciągu dodawany jest znak procentu.
Ta stała, funkcja lub obiekt włączane są przez instrukcję Option VBASupport 1 umieszczoną w module przed programem wykonywalnym.
FormatPercent( expression, [numDigitsAfterDecimal As Integer], [includeLeadingDigit As Integer], _
[useParensForNegativeNumbers As Integer], [groupDigits As Integer] ) As String
String
expression: Wymagany. Wyrażenie liczbowe do sformatowania. Jeśli expression jest łańcuchem znaków, separator dziesiętny i tysiące muszą być zlokalizowane.
numDigitsAfterDecimal: Opcjonalny. Wartość liczbowa określająca liczbę cyfr, które mają być wyświetlane po przecinku. Jeśli zostanie pominięty, przyjmuje wartość domyślną -1, co oznacza, że należy użyć domyślnych ustawień regionalnych interfejsu użytkownika.
includeLeadingDigit: Opcjonalny. Wartość wyliczenia vbTriState, określająca, czy w przypadku wartości ułamkowych ma być wyświetlane wiodące zero.
-
vbTrue lub -1: Wyświetl wiodące zero.
-
vbFalse lub 0: Nie wyświetlaj wiodących zer.
-
vbUseDefault lub -2: Użyj ustawień regionalnych interfejsu użytkownika. Jest to ustawienie domyślne w przypadku pominięcia.
useParensForNegativeNumbers: Opcjonalny. Wartość wyliczenia vbTriState określająca, czy liczby ujemne powinny być ujęte w nawiasy.
-
vbTrue lub -1: Użyj nawiasów dla liczb ujemnych.
-
vbFalse lub 0: Nie wyświetlaj nawiasów.
-
vbUseDefault lub -2: To samo co vbFalse. Jest to ustawienie domyślne w przypadku pominięcia.
groupDigits: Opcjonalny. Wartość wyliczenia vbTriState określająca, że liczba powinna być pogrupowana (w tysiące itp.) przy użyciu ogranicznika grupy określonego w systemowych ustawieniach regionalnych.
-
vbTrue lub -1: Grupuj cyfry.
-
vbFalse lub 0: Nie grupuj cyfr.
-
vbUseDefault lub -2: To samo co vbFalse. Jest to ustawienie domyślne w przypadku pominięcia.
Sub TestFormatNumber
Const UseComputerRegionalSettings = -1
MsgBox FormatPercent(12.2, NumDigitsAfterDecimal:=2)
MsgBox FormatPercent("-,2", 2, IncludeLeadingDigit:=vbTrue)
MsgBox FormatPercent("-0.2", 2)
MsgBox FormatPercent(-0.2, UseComputerRegionalSettings, UseParensForNegativeNumbers:=vbTrue)
MsgBox FormatPercent("-0,2", UseComputerRegionalSettings, vbUseDefault, vbTrue)
MsgBox FormatPercent("-12345678", -1, vbUseDefault, vbUseDefault, GroupDigits:=vbTrue)
End Sub