Компьютерный форум OSzone.net  

Компьютерный форум OSzone.net (http://forum.oszone.net/index.php)
-   AutoIt (http://forum.oszone.net/forumdisplay.php?f=103)
-   -   Перевод числа в пропись (http://forum.oszone.net/showthread.php?t=232909)

iDemon 16-04-2012 07:50 1900464

Перевод числа в пропись
 
Выручайте времени совсем нет.
Нужна подпрограмма, которая переводит деньги из числа в пропись. Например: 10598 р => десять тысяч пятьсот девяносто восемь рублей.
Как это сделать я понимаю, но не когда. Может уже есть готовый код?

Creat0R 16-04-2012 15:07 1900731

Вот вариант на английском, можно перевести значения:

Код:

$iNum = 10598
$sNumName = _NumberNumToName($iNum)
$sNumber = _NumberNameToNum($sNumName)

ConsoleWrite($sNumName & @LF)
ConsoleWrite($sNumber & @LF)

Func _NumberNameToNum($sWord)
        Local $sDigits = "zero|one|two|three|four|five|six|seven|eight|nine"
        Local $sTeens = "eleven|twelve|thirteen|fourteen|fifteen|sixteen|seventeen|eighteen|nineteen"
        Local $sTens = "ten|twenty|thirty|forty|fifty|sixty|seventy|eighty|ninety"
        Local $sBig = "thousand|million|billion|trillion|quadrillion|quintillion|sextillion|septillion|octillion|nonillion|" & _
                "decillion|undecillion|duodecillion|tredecillion|quattuordecillion|quindecillion|sexdecillion|septendecillion|octodecillion|novemdecillion|vigintillion"
       
        Local $asDigits = StringSplit($sDigits, "|", 2)
        Local $asTeens = StringSplit($sTeens, "|", 2)
        Local $asTens = StringSplit($sTens, "|", 2)
        Local $asBig = StringSplit($sBig, "|", 2)
       
        Local $sRet = ""
        Local $iTemp[3] = [0, 0, 0]
        Local $aWords
       
        ; check...
        If Not StringRegExp($sWord, "^(minus\s+)?((((" & $sTens & ")\s+)?(" & $sDigits & ")|(" & $sTeens & ")|(" & $sTens & "))\s+(hundred|" & $sBig & ")(\s+and)?(\s+|\z))*(((" & $sTens & ")\s+)?(" & $sDigits & ")?|(" & $sTeens & ")|(" & $sTens & "))(\s+point(\s+(" & $sDigits & "))+)?$") Then
                Return SetError(1)
        EndIf
       
        $sWord = StringReplace($sWord, " and", "")
       
        For $i = 0 To 8
                $sWord = StringReplace($sWord, $asTeens[$i], "ten " & $asDigits[$i + 1])
        Next
       
        $aWords = StringSplit($sWord, " ")
       
        If StringInStr($sWord, " point ") Then
                Do
                        For $n = 0 To UBound($asDigits) - 1
                                If $asDigits[$n] = $aWords[$aWords[0]] Then
                                        $sRet = $n & $sRet
                                        ExitLoop
                                EndIf
                        Next
                       
                        $aWords[0] -= 1
                Until $aWords[$aWords[0]] <> "point"
               
                $sRet = "." & $sRet
                If $aWords[$aWords[0]] = "zero" Then $sRet = "0" & $sRet
        EndIf
       
        For $i = $aWords[0] To 1 Step -1
                If $i = 1 And $aWords[1] = "minus" Then
                        $sRet = "-" & $sRet
                        ExitLoop
                EndIf
               
                If StringInStr("|" & $sDigits & "|", "|" & $aWords[$i] & "|") Then ; Digit
                        If $iTemp[0] <> 0 Then Return SetError(2, $i, "") ; Invalid word: @extended, expected large identifier not digit.
                       
                        For $n = 0 To UBound($asDigits) - 1
                                If $asDigits[$n] = $aWords[$i] Then
                                        $iTemp[0] = $n
                                        ExitLoop
                                EndIf
                        Next
                ElseIf StringInStr("|" & $sTens & "|", "|" & $aWords[$i] & "|") Then ; Tens
                        If $iTemp[1] <> 0 Then Return SetError(3, $i, "") ; Invalid word: @extended, expected large identifier not ten.
                       
                        For $n = 0 To UBound($asTens) - 1
                                If $asTens[$n] = $aWords[$i] Then
                                        $iTemp[1] = $n + 1
                                        ExitLoop
                                EndIf
                        Next
                ElseIf $aWords[$i] = "hundred" Then ; hundred
                        If $iTemp[2] <> 0 Then Return SetError(4, $i, "") ; Invalid word: @extended, expected large identifier not hundred.
                       
                        For $n = 0 To UBound($asDigits) - 1
                                If $asDigits[$n] = $aWords[$i - 1] Then
                                        $iTemp[2] = $n
                                        $i -= 1
                                        ExitLoop
                                EndIf
                        Next
                ElseIf StringInStr("|" & $sBig & "|", "|" & $aWords[$i] & "|") Then ; BIG
                        $sRet = $iTemp[2] & $iTemp[1] & $iTemp[0] & $sRet
                       
                        $iTemp[0] = 0
                        $iTemp[1] = 0
                        $iTemp[2] = 0
                Else
                        Return SetError(4, $i, "") ; Invalid word: @extended, word not recognized.
                EndIf
        Next
       
        $sRet = $iTemp[2] & $iTemp[1] & $iTemp[0] & $sRet
       
        ; No leading 0's
        While StringLeft($sRet, 1) = "0" And StringLeft($sRet, 2) <> "0."
                $sRet = StringTrimLeft($sRet, 1)
        WEnd
       
        ; No trailing 0's if decimal
        If StringInStr($sRet, ".") Then
                While StringRight($sRet, 1) = "0"
                        $sRet = StringTrimRight($sRet, 1)
                WEnd
               
                If StringRight($sRet, 1) = "." Then $sRet = StringTrimRight($sRet, 1)
        EndIf
       
        Return $sRet
EndFunc

Func _NumberNumToName($iNum)
        $iNum = String($iNum)
        $iNum = StringStripWS($iNum, 8)
        If Not StringRegExp($iNum, "^-?\d+?(\.\d+)?$") Then Return SetError(2, 0, "")
        If $iNum = "0" Then Return "zero"
       
        Local $asDigits[10] = ["zero", "one", "two", "three", "four", "five", "six", "seven", "eight", "nine"]
        Local $asTeens[9] = ["eleven", "twelve", "thirteen", "fourteen", "fifteen", "sixteen", "seventeen", "eighteen", "nineteen"]
        Local $asTens[9] = ["ten", "twenty", "thirty", "forty", "fifty", "sixty", "seventy", "eighty", "ninety"]
        Local $asBig[21] = ["thousand", "million", "billion", "trillion", "quadrillion", "quintillion", "sextillion", "septillion", "octillion", "nonillion", _
                "decillion", "undecillion", "duodecillion", "tredecillion", "quattuordecillion", "quindecillion", "sexdecillion", "septendecillion", "octodecillion", "novemdecillion", "vigintillion"]
       
        ; No leading 0's
        While StringLeft($iNum, 1) = "0" And StringLeft($iNum, 2) <> "0."
                $iNum = StringTrimLeft($iNum, 1)
        WEnd
       
        ; No trailing 0's if decimal
        If StringInStr($iNum, ".") Then
                While StringRight($iNum, 1) = "0"
                        $iNum = StringTrimRight($iNum, 1)
                WEnd
               
                If StringRight($iNum, 1) = "." Then $iNum = StringTrimRight($iNum, 1)
        EndIf
       
        Local $iTemp
        Local $iLen
        Local $sRet = ""
        Local $nDec = ""
       
        ; Do decimal places later
        If StringInStr($iNum, ".") Then
                $nDec = StringMid($iNum, StringInStr($iNum, ".") + 1)
                $iNum = StringLeft($iNum, StringInStr($iNum, ".") - 1)
        EndIf
       
        ; Check negative
        If StringLeft($iNum, 1) = "-" Then
                $iNum = StringTrimLeft($iNum, 1)
                $sRet &= "minus "
        EndIf
       
        ; Very big numbers
        For $i = 21 To 1 Step -1
                If StringLen($iNum) > $i * 3 Then
                        $iLen = Mod(StringLen($iNum), 3)
                        If $iLen = 0 Then $iLen = 3
                       
                        $iTemp = StringLeft($iNum, $iLen)
                        $iNum = StringTrimLeft($iNum, $iLen)
                       
                        $iTemp = _NumberNumToName($iTemp)
                        If $iTemp = "" Or $iTemp = "0" Then ContinueLoop
                        If Not @error Then $sRet &= $iTemp & " " & $asBig[$i - 1] & " "
                EndIf
        Next
       
        ; hundreds
        If StringLen($iNum) >= 3 Then
                $iTemp = StringLeft($iNum, 1)
                $iNum = StringTrimLeft($iNum, 1)
               
                If $iTemp <> "0" Then $sRet &= $asDigits[Int($iTemp)] & " hundred "
                If $iNum <> "00" Then $sRet &= "and "
        EndIf
       
        If StringLen($iNum) = 2 And StringLeft($iNum, 1) = "1" And StringRight($iNum, 1) <> "0" Then
                $iTemp = StringRight($iNum, 1)
                $sRet &= $asTeens[Int($iTemp) - 1] & " "
               
                $iNum = ""
        Else
                ; Tens
                If StringLen($iNum) = 2 Then
                        $iTemp = StringLeft($iNum, 1)
                        $iNum = StringTrimLeft($iNum, 1)
                       
                        If $iTemp <> "0" Then $sRet &= $asTens[Int($iTemp) - 1] & " "
                EndIf
               
                ; Digits
                If StringLen($iNum) = 1 Then
                        If $iNum <> "0" Then $sRet &= $asDigits[Int($iNum)] & " "
                       
                        $iNum = ""
                EndIf
        EndIf
       
        If $nDec <> "" Then
                If $sRet = "" Or $sRet = "minus " Then $sRet &= "zero "
                $sRet &= "point "
               
                Do
                        $iTemp = StringLeft($nDec, 1)
                        $nDec = StringTrimLeft($nDec, 1)
                       
                        $sRet &= $asDigits[Int($iTemp)] & " "
                Until $nDec = ""
        EndIf
       
        $sRet = StringTrimRight($sRet, 1)
       
        Return $sRet
EndFunc


Iska 16-04-2012 15:30 1900749

Creat0R, прямого перевода, вероятно, не получится, ибо у нас есть ещё такое понятие, как род: одна тысяча, но один миллион. Я думаю, проще будет взять любой из работоспособных макросов «число|сумма прописью VBA» и переложить его с VBA на AutoIt. Раньше их немало было на русскоязычных конкурсах Microsoft Office для разработчиков, да и так писал всяк кому не лень свой вариант (даже я ;)).

Creat0R 16-04-2012 16:22 1900787

Цитата:

Цитата Iska
у нас есть ещё такое понятие, как род »

При сильном желании можно это предусмотреть.

apozlevich 16-04-2012 16:26 1900790

Точно видел готовые программки со всеми заморочками.

Creat0R 16-04-2012 16:51 1900814

Цитата:

Цитата Iska
проще будет взять любой из работоспособных макросов «число|сумма прописью VBA» и переложить его с VBA на AutoIt »

Переделал вроде:

Код:

ConsoleWrite(IntToWords(123))

Func ShortNum($num, $razr)
        Dim $hundreds, $tens, $ones, $razryad
        Dim $hundreds[10] = ["", " сто", " двести", " триста", " четыреста", " пятьсот", " шестьсот", " семьсот", " восемьсот", " девятьсот"]
        Dim $tens[10] = ["", "", " двадцать", " тридцать", " сорок", " пятьдесят", " шестьдесят", " семьдесят", " восемьдесят", " девяносто"]
        Dim $ones[20] = ["", "", "", " три", " четыре", " пять", " шесть", " семь", " восемь", " девять", " десять", " одиннадцать", " двенадцать", " тринадцать", " четырнадцать", " пятнадцать", " шестнадцать", " семнадцать", " восемнадцать", " девятнадцать"]
        Dim $razryad[7] = ["", " тысяч", " миллион", " миллиард", " триллион", " квадриллион", " квинтиллион"]
       
        Dim $t, $o
       
        $result = $hundreds[$num / 100]
       
        If $num = 0 Then Return
       
        $t = Mod($num, 100) / 10
        $o = Mod($num, 10)
       
        If $t <> 1 Then
                $result &= $tens[$t]
               
                Switch $o
                        Case 1
                                If $razr = 1 Then
                                        $result &= " одна"
                                Else
                                        $result &= " один"
                                EndIf
                        Case 2
                                If $razr = 1 Then
                                        $result &= " две"
                                Else
                                        $result &= " два"
                                EndIf
                        Case 3, 4, 5, 6, 7, 8, 9
                                $result &= $ones[$o]
                EndSwitch
               
                $result &= $razryad[$razr]
               
                Switch $o
                        Case 1
                                If $razr = 1 Then
                                        $result &= "а"
                                EndIf
                        Case 2, 3, 4
                                If $razr = 1 Then
                                        $result &= "и"
                                ElseIf $razr > 1 Then
                                        $result &= "а"
                                EndIf
                        Case Else
                                If ($razr > 1) Then
                                        $result &= "ов"
                                EndIf
                EndSwitch
               
        Else
                $result &= $ones[Mod($num, 100)]
                $result &= $razryad[$razr]
               
                If $razr > 1 Then
                        $result &= "ов"
                EndIf
        EndIf
       
        Return $result
EndFunc

Func IntToWords($s)
        Dim $i, $count
       
        If (StringLen($s) = 0) Or ($s = "0") Then
                Return "ноль"
        EndIf
       
        $count = (StringLen($s) + 2) / 3
       
        If $count > 7 Then
                Return "Value is too large"
        EndIf
       
        $result = ""
       
        For $i = 1 To $count
                $result = ShortNum((StringMid($s, StringLen($s) - 3 * $i + 1, 3)), $i - 1) & $result
        Next
       
        If StringLen($result) > 0 Then
                $result = StringRight($result, StringLen($result) - 1)
        EndIf
       
        If $result = "" Then $result = $s
       
        Return $result
EndFunc

Но есть многие недоработки.

apozlevich 16-04-2012 16:59 1900817

Продолжаю оффтопить: а зачем использовать именно AutoIt? Можно же и с VBA работать

Creat0R 16-04-2012 17:06 1900821

Цитата:

Цитата apozlevich
Продолжаю оффтопить »

Заканчивай.

Цитата:

Цитата apozlevich
Можно же и с VBA работать »

Покажи мне нормально решение на нём, и будет решение на AutoIt.

apozlevich 16-04-2012 17:38 1900838

Цитата:

Цитата Creat0R
Цитата:

Цитата Iska
проще будет взять любой из работоспособных макросов «число|сумма прописью VBA» и переложить его с VBA на AutoIt

Переделал вроде

Создается впечатление, что вы переписали код с VBA на AutoIt. Или это код из первого поста?

А вообще, я просто присоединился к Iska с его вторым постом
Цитата:

Цитата Iska
Я думаю, проще будет взять любой из работоспособных макросов «число|сумма прописью VBA» »

Но
Цитата:

Цитата apozlevich
Можно же и с VBA работать »


iDemon 16-04-2012 18:16 1900864

У меня уже 30 кб кода куда нужно присобачить программу для перевода на autoit, а на vba это было бы раза в два больше. Можно и с VBA работать можно на ассемблере вообще писать, мне на autoit надо. Ладно деваться некуда пойду писать.

Creat0R 16-04-2012 18:32 1900879

Цитата:

Цитата apozlevich
Создается впечатление, что вы переписали код с VBA на AutoIt »

Так и сеть.

AZJIO 16-04-2012 19:27 1900913

тест6

Код:

#include <_NumberNumToName.au3>

$sRes = ''
For $i = 1 To 10
    $sRes &= _FuncName(Random(1, 10000000000, 1))
Next

$sRes &= _FuncName(000018)
$sRes &= _FuncName(118)
$sRes &= _FuncName(200)
$sRes &= _FuncName(5)
$sRes &= _FuncName(18000000000)
$sRes &= _FuncName(9223372036854775806) ; максимальное число
$sRes &= _FuncName(9223372036854775807) ; максимальное число поддерживаемое AutoIt3
$sRes &= _FuncName(0)

MsgBox(0, 'Сообщение', $sRes)

Func _FuncName($iNumber)
    Return StringRegExpReplace($iNumber, '(\A\d{1,3}(?=(\d{3})+\z)|\d{3}(?=\d))', '\1 ') & ' = ' & _NumberNumToName($iNumber) & @CRLF
EndFunc

; ============================================================================================
; Имя функции ...: _NumberNumToName
; Описание ........: Преобразует число в запись прописью
; Синтаксис.......: _NumberNumToName($iNumber)
; Параметры:
;      $iNumber - любое целое число от 0 до 9223372036854775806
; Возвращаемое значение: Успешно - число прописью
;                  Неудачно - пустая строка, @error = 1, если строка содержит не цифры
; Автор ..........: AZJIO, преобразование и модернизация VBS-скрипта, найденного в Google
; Ссылка ..........: http://forum.oszone.net/post-1900913.html#post1900913 обсуждение и добавление CreatoR'ом поддержки английского языка
; ============================================================================================

Func _NumberNumToName($iNumber)
    Local $aN, $aNum, $c, $i, $j, $n, $r, $sText
    $iNumber
= StringStripWS($iNumber, 8) ; удаляем пробелы
    If $iNumber = '0' Then Return 'ноль'
    $iNumber = Int($iNumber) ; берём целую часть числа
    If Not StringIsDigit($iNumber) Or $iNumber>9223372036854775806 Or $iNumber=0 Then Return SetError(1, 0, '') ; если не цифры или огромное число, то вылет
    $iNumber = StringRegExpReplace($iNumber, '(\A\d{1,3}(?=(\d{3})+\z)|\d{3}(?=\d))', '\1 ') ; dwerf
    $aNum = StringSplit($iNumber, ' ')
    Local $a[4][10] = [[' десять', ' одиннадцать', ' двенадцать', ' тринадцать', ' четырнадцать', ' пятнадцать', ' шестнадцать', ' семнадцать', ' восемнадцать', ' девятнадцать'],['', ' сто', ' двести', ' триста', ' четыреста', ' пятьсот', ' шестьсот', ' семьсот', ' восемьсот', ' девятьсот'],['', '', ' двадцать', ' тридцать', ' сорок', ' пятьдесят', ' шестьдесят', ' семьдесят', ' восемьдесят', ' девяносто'],['', '', '', ' три', ' четыре', ' пять', ' шесть', ' семь', ' восемь', ' девять']]
    Local $razryad[7] = ['', ' тысяч', ' миллион', ' миллиард', ' триллион', ' квадриллион', ' квинтиллион']

    $aNum[1] = StringFormat('%03s', $aNum[1]) ; дополняем нулями недостающие разряды
    $sText = ''
    For $i = 1 To $aNum[0]
        If $aNum[$i]='000' Then ContinueLoop
        $aN = StringSplit($aNum[$i], '')
        $r=$aNum[0] - $i
        For $j = 1 To $aN[0]
            $n=Number($aN[$j])
            If Not $n Then ContinueLoop
            $c = $j
            Switch $j
                Case 3
                    Switch $n ; для чисел 1 или 2
                        Case 1
                            If $r = 1 Then ; разряд единиц (не десятков и сотен)
                                $sText &= " одна"
                            Else
                                $sText &= " один"
                            EndIf
                        Case
2
                            If $r = 1 Then
                                $sText &= " две"
                            Else
                                $sText &= " два"
                            EndIf
                    EndSwitch
                Case
2 ; для чисел от 10 до 19
                    If $n = 1 Then
                        $c = 0
                        $n = Number($aN[3])
                        $aN[3]=0
                    EndIf
            EndSwitch

            $sText &= $a[$c][$n] ; присоединения числа из массива
        Next
        $sText &= $razryad[$r]
        Switch $n ; окончания для раряда кратного 1000, при $j=3 в конце цикла
            Case 1
                If $r = 1 Then ; одна тысяч<а>
                    $sText &= "а"
                EndIf
            Case
2, 3, 4
                If $r = 1 Then ; 2,3,4 тысяч<и>
                    $sText &= "и"
                ElseIf $r > 1 Then ; 2,3,4 милион<а>
                    $sText &= "а"
                EndIf
            Case Else
                If
$r > 1 Then ; 5-9 милион<ов>
                    $sText &= "ов"
                EndIf
        EndSwitch
    Next
    Return
$sText
EndFunc


apozlevich 17-04-2012 19:18 1901454

http://chislopropisyu.appspot.com/
Простой сервис для сабжа.

madmasles 17-04-2012 20:56 1901496

Цитата:

Цитата apozlevich
Простой сервис »

Максимальное число 999 999 999.
Код:

$iDig = 99999999
$sUrl = 'http://chislopropisyu.appspot.com/ajax?do_what=dig&dig=' & $iDig
$s_Sourse = InetRead($sUrl, 17)
If @error Then
    ConsoleWrite('Error' & @LF)
Else
    $s_Sourse = BinaryToString($s_Sourse, 4)
    $s_Sourse = StringRegExpReplace($s_Sourse, '.*string".*?"(.+?)"}.*', '$1')
    ConsoleWrite($s_Sourse & @LF)
EndIf


Creat0R 28-04-2012 18:57 1907424

AZJIO
Немного подредактировал код, теперь поддерживается и английский язык:

Код:

$iNumber = Random(1, 10000000000, 1)
$sRus_Number = _NumberNumToName($iNumber, 1)
$sEng_Number = _NumberNumToName($iNumber, 0)

MsgBox(64, '_NumberNumToName', $iNumber & ' = ...' & @CRLF & @CRLF & 'Eng: ' & $sRus_Number & @CRLF & @CRLF & 'Rus: ' & $sEng_Number)



; AZJIO, преобразование и модернизация VBS-скрипта, найденного в Google
; http://forum.oszone.net/post-1900913.html#post1900913
; Преобразует число в запись прописью. Параметр $iNum - любое целое число от 1 до 9223372036854775806
Func _NumberNumToName($iNum, $iRusLng = 0)
    Local $aN, $aNum, $c, $i, $j, $n, $r, $sText

    $iNum = StringStripWS($iNum, 8) ; удаляем пробелы

    If $iNum = '0' Then
        If $iRusLng Then Return 'Ноль'
        Return 'Zero'
    EndIf

    $iNum = Int($iNum) ; берём целую часть числа
    If Not StringIsDigit($iNum) Or $iNum > 9223372036854775806 Or $iNum = 0 Then Return SetError(1, 0, '') ; если не цифры или огромное число, то вылет

    $iNum = StringRegExpReplace($iNum, '(\A\d{1,3}(?=(\d{3})+\z)|\d{3}(?=\d))', '\1 ') ; dwerf
    $aNum = StringSplit($iNum, ' ')

    If $iRusLng Then
        Dim $a[4][10] = _
            [ _
                [' десять', ' одиннадцать', ' двенадцать', ' тринадцать', ' четырнадцать', ' пятнадцать', ' шестнадцать', ' семнадцать', ' восемнадцать', ' девятнадцать'], _
                ['', ' сто', ' двести', ' триста', ' четыреста', ' пятьсот', ' шестьсот', ' семьсот', ' восемьсот', ' девятьсот'], _
                ['', '', ' двадцать', ' тридцать', ' сорок', ' пятьдесят', ' шестьдесят', ' семьдесят', ' восемьдесят', ' девяносто'], _
                ['', '', '', ' три', ' четыре', ' пять', ' шесть', ' семь', ' восемь', ' девять'] _
            ]

        Dim $aBitNum[7] = ['', ' тысяч', ' миллион', ' миллиард', ' триллион', ' квадриллион', ' квинтиллион']
    Else
        Dim $a[4][10] = _
            [ _
                [' ten', ' eleven', ' twelve', ' thirteen', ' fourteen',' fifteen', ' sixteen', ' seventeen', ' eighteen', ' nineteen'], _
                ['', 'hundred', ' two hundred', ' three hundred', ' four hundred', ' five hundred', ' six hundred', ' seven hundred', ' eight hundred', ' nine hundred'], _
                ['','', ' twenty', ' thirty', ' forty', ' fifty', ' sixty', ' seventy', ' eighty', ' ninety'], _
                ['','','', ' three', ' four', ' five', ' six', ' seven', ' eight', ' nine'] _
            ]

        Dim $aBitNum[7] = ['', ' thousand', ' million', ' billion', ' trillion', ' quadrillion', ' quintillion']
    EndIf

    $aNum[1] = StringFormat('%03s', $aNum[1]) ; дополняем нулями недостающие разряды
    $sText = ''

    For $i = 1 To $aNum[0]
        If $aNum[$i] = '000' Then ContinueLoop

        $aN = StringSplit($aNum[$i], '')
        $r = $aNum[0] - $i

        For $j = 1 To $aN[0]
            $n = Number($aN[$j])
            If Not $n Then ContinueLoop

            $c = $j

            Switch $j
                Case 3
                    Switch $n ; для чисел 1 или 2
                        Case 1
                            If $iRusLng Then
                                If $r = 1 Then ; разряд единиц (не десятков и сотен)
                                    $sText &= " одна"
                                Else
                                    $sText &= " один"
                                EndIf
                            Else
                                $sText &= " one"
                            EndIf
                        Case 2
                            If $iRusLng Then
                                If $r = 1 Then
                                    $sText &= " две"
                                Else
                                    $sText &= " два"
                                EndIf
                            Else
                                $sText &= " two"
                            EndIf
                    EndSwitch
                Case 2 ; для чисел от 10 до 19
                    If $n = 1 Then
                        $c = 0
                        $n = Number($aN[3])
                        $aN[3] = 0
                    EndIf
            EndSwitch

            $sText &= $a[$c][$n] ; присоединения числа из массива
        Next

        $sText &= $aBitNum[$r]

        Switch $n ; окончания для раряда кратного 1000, при $j=3 в конце цикла
            Case 1
                If $r = 1 And $iRusLng Then ; одна тысяч<а>
                    $sText &= "а"
                EndIf
            Case 2, 3, 4
                If $r = 1 Then ; 2,3,4 тысяч<и>
                    If $iRusLng Then
                        $sText &= "и"
                    Else
                        $sText &= "s"
                    EndIf
                ElseIf $r > 1 Then ; 2,3,4 милион<а>
                    If $iRusLng Then
                        $sText &= "а"
                    Else
                        $sText &= "s"
                    EndIf
                EndIf
            Case Else
                If $r > 1 Then ; 5-9 милион<ов>
                    If $iRusLng Then
                        $sText &= "ов"
                    Else
                        $sText &= "s"
                    EndIf
                EndIf
        EndSwitch
    Next

    Return StringStripWS($sText, 3)
EndFunc



Время: 18:46.

Время: 18:46.
© OSzone.net 2001-