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

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


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

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

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

Botsman
Статус: 7-й класс
Рейтинг: 70
∙ повысить рейтинг >>
Megaloman
Статус: Практикант
Рейтинг: 25
∙ повысить рейтинг >>
Архипов Александр Леонидович
Статус: Практикант
Рейтинг: 20
∙ повысить рейтинг >>

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

Выпуск № 864
от 20.02.2009, 08:35

Администратор:Калашников О.А.
В рассылке:Подписчиков: 275, Экспертов: 26
В номере:Вопросов: 1, Ответов: 2

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

Вопрос № 160497: Пишу небольшую программу на VBA (под Excel). Подскажите, пожалуйста, можно ли "заставить" Excel VBA работать с контролами для .NET. Конкретно мне нужен элемент управления DataGridView. Я пытался добавить его в Toolbox через меню "Addit...


Вопрос № 160.497
Пишу небольшую программу на VBA (под Excel). Подскажите, пожалуйста, можно ли "заставить" Excel VBA работать с контролами для .NET. Конкретно мне нужен элемент управления DataGridView. Я пытался добавить его в Toolbox через меню "Additional Controls", но там в списке не оказалось DataGridView. Затем я попытался добавить ссылку на System.Windows.Forms.dll (через Tools --- References), но получилась ошибка: "Can't add a reference to the specified file".
Если использовать DataGridView в VBA Excel никак нельзя, то, может быть, кто нибудь знает альтернативный элемент управления, доступный для VBA Excel? Мне нужен любой элемент управления в виде таблицы, которую можно связать с базой данных (mdb, Access) или не связывать, а заполнить вручную по строкам и столбцам. Кроме того, нужно дать возможность пользователю редактировать данные. Также желательно, чтобы элемент управления мог реагировать на клик мышью по строке (генерировать событие и давать сведения, по какой строке и колонке щелкнули).
Заранее спасибо тем, кто ответит.
Отправлен: 15.02.2009, 01:59
Вопрос задал: Гамов Артем Борисович (статус: Посетитель)
Всего ответов: 2
Мини-форум вопроса >>> (сообщений: 9)

Отвечает: Botsman
Здравствуйте, Гамов Артем Борисович!

К сожалению, не знаю всей специфики вашей программы, но судя по тому, что вы указали в вопросе, хочу предложить вам использовать в excel - как это не парадоксально - лист excel в качестве альтернативного инструмента, потому что:
1) это таблица
2) данные можно вносить руками
3) его можно связать с базой данных ассеss следующим образом. Например, у вас есть база данных db1.mdb и открыта книга excel, в которую выбудете импортировать данные. Если у вас excel 2003 (если нет - пишите, разберемся), выбираем пункт меню Данные->Импорт внешних данных->Импортировать данные... Откроется окно Выбор источника данных. Выбираем Подключение к новому источнику данных и нажимаем Создать. В окне запустившегося Мастера подключения данных выбираем Тип источника ODBC DSN -> Далее -> База данных MS Access. Появится окно, где находим свою базу (нужно знать, где она находится и как называется), жмем ОК. Выбираем таблицы, к которым нужно подключиться. Далее. Вводим название и комментарии. Нажимаем Готово. Появится окно "Импорт данных", где выбираем ячейку, куда (т.е. левее и ниже) будут выводиться данные. И ОК. На этом импорт завершен.
4) Редактировать данные можно, но заливку их в базу вам в любом случае обрабатывать.
5) Лист реагирует на клик мышью по строке. Например, если вставить в активный лист (именно в лист, не в модуль) процедуру следующего содержания

Sub Worksheet_SelectionChange(ByVal Target As Range)
MsgBox (ActiveCell.Row)
End Sub

то при любом щелчке мышью на этом листе будет высвечиваться окошко, в котором сообщается номер активной строки.

Вот вроде бы все.
Буду очень рад, если смог вам помочь.

PS Нет большей радости для эксперта, чем обратная связь и адекватная оценка ;)
---------
Хочешь победить Excel? Спроси меня как! ;)
Ответ отправил: Botsman (статус: 7-й класс)
Ответ отправлен: 17.02.2009, 15:11

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

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо за подробный ответ.


    Отвечает: Тесленко Евгений Алексеевич
    Здравствуйте, Гамов Артем Борисович!
    Grid.rar образец применения DataGrid для связи с базой данных (mdb).
    Евгений.
    Ответ отправил: Тесленко Евгений Алексеевич (статус: Практикант)
    Ответ отправлен: 18.02.2009, 00:30

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

    Оценка за ответ: 5
    Комментарий оценки:
    Спасибо за ответ, хотя, у меня DataGrid, к сожалению, так и не появился.


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

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

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

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

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

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

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

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


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное