Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на Basic / VBA


Хостинг портала RFpro.ru:
Московский хостер
Профессиональный платный хостинг на базе Windows 2008

РАССЫЛКИ ПОРТАЛА RFPRO.RU

Чемпионы рейтинга экспертов в этой рассылке

Botsman
Статус: Специалист
Рейтинг: 516
∙ повысить рейтинг »
Гуревич Александр Львович
Статус: 9-й класс
Рейтинг: 481
∙ повысить рейтинг »
Megaloman
Статус: Бакалавр
Рейтинг: 473
∙ повысить рейтинг »

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / Basic/VBA

Номер выпуска:932
Дата выхода:23.09.2009, 16:30
Администратор рассылки:Калашников О.А., Руководитель
Подписчиков / экспертов:363 / 92
Вопросов / ответов:1 / 1

Вопрос № 172280: Здраствуйте Уважаемые эксперты. Программирую VBA. Не могу понять в чем моя ошибка, что у меня выполяется не то что надо. Есть форма, обьявлены несколько пременных в модуле. И по нажатию на одну из кнопок действие(Смотрите приложение). Я хоч...



Вопрос № 172280:

Здраствуйте Уважаемые эксперты.
Программирую VBA. Не могу понять в чем моя ошибка, что у меня выполяется не то что надо.
Есть форма, обьявлены несколько пременных в модуле. И по нажатию на одну из кнопок действие(Смотрите приложение).
Я хочу сделать так, чтобы если число в textbox1.text больше чем textbox4.text то выводится число из textbox4.text в метке.
Проблема:
К примеру пишу такие числа 100 > 55
В метке ничего не выводится.
Если пишу 100 > 0,9 то все выводится. Как будто бы сравнение идет по первой цифре.
Пробовал еще и такую конструкцию:
Private Sub Button1_Click()
t1 = Formm.TextBox1.Text
t2 = Formm.TextBox4.Text
Label12.Caption = t1
Label13.Caption = t2
If t1 > t2 Then
Label14.Caption = t2
End If
End Sub

Не помогло. Тотже результат.
Помогите решить проблему.

Отправлен: 17.09.2009, 19:44
Вопрос задал: Dimon4ik, 4-й класс
Всего ответов: 1
Страница вопроса »


Отвечает Витер Александр Анатольевич, 9-й класс :
Здравствуйте, Dimon4ik.
Вы пытаетесь сравнивать строки. Сравнение происходит по ASCII кодам первых символов строк. Если вы хотите сравнивать числа, то нужно преобразовать строку в число, а затем сравнивать. Например, так
Код:
Private Sub Button1_Click()
Dim t1 As Single, t2 As Single
t1 = CSng(Formm.TextBox1.Text)
t2 = CSng(Formm.TextBox4.Text)
Label12.Caption = CStr(t1)
Label13.Caption = CStr(t2)
If t1 > t2 Then
Label14.Caption = CStr(t2)
End If
End Sub

Переменные я объявил как Single, а не как Double, потому что никакой необходимости в повышенной точности нет. Переменные типа Single могут иметь значения от -3.402823•1038 до -1.401298•-45 для отрицательн ых значений и от 1.401298•-45 до 3.402823•38 для положительных. Думаю, что для вашей задачи этого хватит за глаза.
-----
Лучше день потерять - потом за пять минут долететь!

Ответ отправил: Витер Александр Анатольевич, 9-й класс
Ответ отправлен: 17.09.2009, 20:40

Оценка ответа: 5
Комментарий к оценке:
Спасибо. Теперь все работает!

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 254317 на номер 1151 (Россия) | Еще номера »
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Оценить выпуск »
    Нам очень важно Ваше мнение об этом выпуске рассылки!

    Задать вопрос экспертам этой рассылки »

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров »

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RFpro.ru, Россия
    Авторское право: ООО "Мастер-Эксперт Про"
    Автор: Калашников О.А. | Программирование: Гладенюк А.Г.
    Хостинг: Компания "Московский хостер"
    Версия системы: 2009.6.9 от 22.09.2009

    В избранное