Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.63/68: Рейтинг темы: голосов - 68, средняя оценка - 4.63
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
1

TextBox - денежный формат

27.06.2011, 06:36. Показов 12359. Ответов 22
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Плиииззз, подскажите пожалуйста как при вводе в TextBox можно было вводить только числа, и если пользователь вводит точку то она автоматически менялась на запятую. И допустим мы вводим 1923000 то это число автоматически выглядело бы как 1 923 000,00 (Как в Excel денежный формат)
Миниатюры
TextBox - денежный формат  
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.06.2011, 06:36
Ответы с готовыми решениями:

Формат в Textbox (000.00)
Прочитал тему но не смог под себя подстроить. Не могу заставить в Textbox1 водиться только...

Денежный формат
Правильно ли я понимаю что для учета сумм в деньгах предпочтительней использовать Денежный формат....

денежный формат
Доброго времени суток форумчане :) Подскажите как отобразить в двух последних столбцах Stringgrida...

Денежный формат
Добрый вечер! Подскажите, пожалуйста, как в отчете отобразить суммы в миллионах рублей? Что-то...

22
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
27.06.2011, 09:04 2
VB.NET
1
TextBox1.Text = String.Format("{0:c}", TextBox1.Text)
Устроит?
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
27.06.2011, 10:53  [ТС] 3
Че то не работает, есть FormatCurrency но не могу применить((((
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
27.06.2011, 11:04 4
Сорри
VB.NET
1
2
        Dim Valuta As Double = TextBox1.Text
        TextBox1.Text = String.Format("{0:c}", Valuta)
1
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
27.06.2011, 13:10  [ТС] 5
Вот сейчас работает)))))Спасибо

Добавлено через 12 минут
А при стирании числа выскакивает ошибка "Приведение строки "" к типу "Double" является недопустимым"
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
27.06.2011, 13:50 6
GRURUS, и с ним нельзя не согласиться, не так ли?
Поставь в проверку содержимое, мол, если пусто или
VB.NET
1
IsNumeric = ФальШ
, тогда никаких обработок, в противном случае - валяй.
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
27.06.2011, 13:58  [ТС] 7
И еще как можно собрать твой код для перевода в денежный вариант со следующи кодом

VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
Private Sub TextBox_KeyPress(ByVal sender As Object, ByVal e As System.Windows.Forms.KeyPressEventArgs) Handles TextBox.KeyPress 
 
        Dim c As Char = e.KeyChar 
        If Char.IsDigit(c) Or Char.IsPunctuation(c) Then 
            If Char.IsPunctuation(c) Then 
                If sender.text.contains(",") Then   
                    e.Handled = True 
                Else 
                    e.KeyChar = Chr(44) 
                End If 
            End If 
        ElseIf Asc(c) = 8 Then 
        Else 
            e.Handled = True 
        End If 
    End Sub
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
27.06.2011, 14:20 8
Страшно даже помыслить, чтобы это все применялось при вводе текста.
Например, я бы на месте компиллятора не знал, что делать, а ты?
Выход:
Рисуем деньги в момент выхода из текстового поля, т.е. потери фокуса:
VB.NET
1
2
3
4
5
6
7
    Private Sub TextBox1_LostFocus(ByVal sender As Object, ByVal e As System.EventArgs) Handles TextBox1.LostFocus
        TextBox1.Text = TextBox1.Text.Replace(".", ",")
        If IsNumeric(TextBox1.Text) = True And TextBox1.Text <> "" Then
            Dim Valuta As Double = TextBox1.Text
            TextBox1.Text = String.Format("{0:c}", Valuta)
        End If
    End Sub
А то что ты там изобрел - это атомная бомба.
2
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
28.06.2011, 09:02  [ТС] 9
Все гут, но есть одно но...ввожу 4568 переводится в 4 568,00р. а когда надо посчитать по берется не 4568 а 4
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
28.06.2011, 09:08 10
Как посчитать? Пример?

Добавлено через 3 минуты
VB.NET
1
MsgBox((TextBox1.Text) + 13)
По моему работает неплохо
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
28.06.2011, 10:00  [ТС] 11
х.з этот примр работает,а у меня округляет

Добавлено через 12 минут
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
Public Class Form1
    Dim A, B, X, Valuta As Double
    Private Sub TextBox1_LostFocus(ByVal sender As Object, ByVal e As System.EventArgs) Handles TextBox1.LostFocus
        TextBox1.Text = TextBox1.Text.Replace(".", ",")
        If IsNumeric(TextBox1.Text) = True And TextBox1.Text <> "" Then
            Valuta = TextBox1.Text
            TextBox1.Text = String.Format("{0:c}", Valuta)
        End If
        A = Val(TextBox1.Text)
    End Sub
    Private Sub TextBox2_LostFocus(ByVal sender As Object, ByVal e As System.EventArgs) Handles TextBox2.LostFocus
        TextBox2.Text = TextBox1.Text.Replace(".", ",")
        If IsNumeric(TextBox2.Text) = True And TextBox2.Text <> "" Then
            Valuta = TextBox2.Text
            TextBox2.Text = String.Format("{0:c}", Valuta)
        End If
        B = Val(TextBox2.Text)
    End Sub
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        X = A * (A + B)
        MsgBox(X)
    End Sub
End Class
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
28.06.2011, 10:55 12
VB.NET
1
TextBox2.Text = TextBox1.Text.Replace(".", ",")
Ты тут не напутал? Это во втором текстбоксе, приравнивание к первому - это так задумано?
Если нет, то вот такой вариант попробуй:
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
    Dim A, B, X, Valuta As Double
    Private Sub TextBox1_LostFocus(ByVal sender As Object, ByVal e As System.EventArgs) Handles TextBox1.LostFocus
        TextBox1.Text = TextBox1.Text.Replace(".", ",")
        If IsNumeric(TextBox1.Text) = True And TextBox1.Text <> "" Then
            Valuta = TextBox1.Text
            TextBox1.Text = String.Format("{0:c}", Valuta)
            A = CDbl(TextBox1.Text)
        End If
    End Sub
    Private Sub TextBox2_LostFocus(ByVal sender As Object, ByVal e As System.EventArgs) Handles TextBox2.LostFocus
        TextBox2.Text = TextBox2.Text.Replace(".", ",")
        If IsNumeric(TextBox2.Text) = True And TextBox2.Text <> "" Then
            Valuta = TextBox2.Text
            TextBox2.Text = String.Format("{0:c}", Valuta)
            B = CDbl(TextBox2.Text)
        End If
    End Sub
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        X = A * (A + B)
        MsgBox(String.Format("{0:c}", X))
    End Sub
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
28.06.2011, 11:13  [ТС] 13
ну да косячек(((

Добавлено через 8 минут
все работает, а можно реализовать если после зяпятой нули то их отбрасывать
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
28.06.2011, 11:15 14
Цитата Сообщение от GRURUS Посмотреть сообщение
если после зяпятой нули то их отбрасывать
Где? Не понял
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
28.06.2011, 11:20  [ТС] 15
допустим получается число 6 000,00р. при выводе результата в textbox 6 000р.
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
28.06.2011, 11:24 16
GRURUS, Ты вроде так боролся за копейки, теперь тебе их не надо?
Замени
VB.NET
1
MsgBox(String.Format("{0:c}", X))
На
VB.NET
1
MsgBox(X)
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
28.06.2011, 11:28  [ТС] 17
в чем фишка если 6 000, 56р. то выводим 6 000,56р, а если 6 000,00р, то выводим 6 000
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
28.06.2011, 11:30 18
GRURUS, см. выше, как раз то что надо
0
9 / 9 / 4
Регистрация: 27.06.2011
Сообщений: 295
28.06.2011, 11:33  [ТС] 19
это я понимаю, но я же незнаю изначально какой у меня результат будет
0
Почетный модератор
21409 / 9143 / 1083
Регистрация: 11.04.2010
Сообщений: 11,014
28.06.2011, 11:49 20
GRURUS, разбирайся давай пробуй, все выложено. А то я уже тебя понимать перестал
0
28.06.2011, 11:49
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.06.2011, 11:49
Помогаю со студенческими работами здесь

Денежный формат и запросы
Добрый вечер, есть база поля денежные 2 знака, при выполнении запросов на суммирование получаю...

Сделать денежный формат
Как из полученных цифр, сделать денежный формат в рублях Пробовал money_format() и...

Денежный формат в SQLite
Как в SQLite в столбце цены изменить валюту с рублей на доллар например?

Денежный формат в DBGrid
Как сделать денежный формат в одной ячейке DBGrid? Надо чтобы отображались копейки и еще через...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru