Кто знает VBA?

ArcGIS 8.x,9.x,10.x (Arcview, ArcEditor, Arcinfo).
Ответить
KatenoK
Новоприбывший
Сообщения: 13
Зарегистрирован: 16 ноя 2011, 12:40
Репутация: 0

Кто знает VBA?

Сообщение KatenoK » 17 ноя 2011, 10:27

Помогите выполнить задание в ArcMap! Никак не могу найти такие макросы на VBA, а сама ничего писать не умею :(
Задание ваще для программистов, а я всего лишь географ и никогда никакой язык не изучала! У препода спрашиваешь, а он только: "Разбирайтесь сами!". Короче, если кто сможет помочь, буду очень признательна.
Задание такое:
1. Написать макрос, который удаляет поле из таблицы атрибутов. Название слоя и удаляемого поля запрашиваются у пользователя.
2. Написать макрос, который добавляет поле Pop2008 в таблицу атрибутов слоя (н-р, MEXCITY).
3. Написать макрос, который
• увеличивает на 30% значения поля Population слоя MEXCITY и записывает эти значения в поле Pop2008.
• вычисляет значение поля, используя значения уже существующего поля
4. Написать макрос, который создает поле Type в таблице атрибутов слоя MEXCITY и вносит в него значение, равное 1, если население города превышает 1000000.
5. Добавить в проект VBA пользовательскую форму. На этапе проектирования добавить на форму две кнопки (CommandButton), две метки (Label) и список выбора (ListBox). После запуска проекта на выполнение, на форме появляется группа переключателей, подписи которых – имена слоев. Щелчок по переключателю выводит в ListBox список атрибутов соответствующего слоя. Щелчок по кнопке «Добавить атрибут» добавляет поле в таблицу атрибутов отмеченного слоя, название атрибута запрашивается. Щелчок по кнопке «Удалить атрибут» удаляет выбранное поле из таблицы атрибутов отмеченного слоя.

Александр Мурый
Гуру
Сообщения: 5173
Зарегистрирован: 26 сен 2009, 16:26
Репутация: 792
Ваше звание: званий не имею
Откуда: Москва

Re: Кто знает VBA?

Сообщение Александр Мурый » 17 ноя 2011, 10:32

Мне кажется, или пункты 1-4 -- это чистой воды SQL и никаких макросов там не надо?
Редактор материалов, модератор форума

Аватара пользователя
novia
Гуру
Сообщения: 2261
Зарегистрирован: 29 апр 2011, 15:06
Репутация: 489
Откуда: Тель-Авив

Re: Кто знает VBA?

Сообщение novia » 17 ноя 2011, 10:36

Это практикум по программированию на VBA, или вам просто нужно функциональность реализовать?

Если второе и все должно работать в ArcMap, то для первых четырех задач не вижу смысла писать макросы, если можно собрать предварительно настроенные модели геообработки и запускать их из собственного набора инструментов ToolBox.
1. Написать макрос, который удаляет поле из таблицы атрибутов. Название слоя и удаляемого поля запрашиваются у пользователя.
есть же стандартный и доступный на любом уровне лицензий инструмент геообработки - Удалить поле (Delete field)
2. Написать макрос, который добавляет поле Pop2008 в таблицу атрибутов слоя (н-р, MEXCITY).
то же самое - Добавить поле (Add field)
3. Написать макрос, который
• увеличивает на 30% значения поля Population слоя MEXCITY и записывает эти значения в поле Pop2008.
• вычисляет значение поля, используя значения уже существующего поля
инструмент Вычислить значения поля (Calculate field). расчет на основе имеющегося значения для нового значения в одном и том же поле тоже поддерживается.
4. Написать макрос, который создает поле Type в таблице атрибутов слоя MEXCITY и вносит в него значение, равное 1, если население города превышает 1000000.
см. предыдущий инструмент
понравилось? жми палец вверх :!:

KatenoK
Новоприбывший
Сообщения: 13
Зарегистрирован: 16 ноя 2011, 12:40
Репутация: 0

Re: Кто знает VBA?

Сообщение KatenoK » 17 ноя 2011, 12:33

Это практикум по VBA. Надо именно на нем все написать. Типа создал кнопочку, вставил макрос и - клик - и все сделалось.

Аватара пользователя
Дмитрий Барышников
Гуру
Сообщения: 2572
Зарегистрирован: 17 ноя 2009, 19:17
Репутация: 261
Откуда: Москва

Re: Кто знает VBA?

Сообщение Дмитрий Барышников » 17 ноя 2011, 15:07

А ведь вслед за Microsoft, ESRI начиная с 10 версии отказалось от VBA - вас учат ненужной технологии!
http://blogs.gis-lab.info/bishop/2011/1 ... tion-plan/

gamm
Гуру
Сообщения: 4168
Зарегистрирован: 15 окт 2010, 08:33
Репутация: 1107
Ваше звание: программист
Откуда: Казань

Re: Кто знает VBA?

Сообщение gamm » 17 ноя 2011, 17:29

Bishop писал(а):А ведь вслед за Microsoft, ESRI начиная с 10 версии отказалось от VBA - вас учат ненужной технологии!
http://blogs.gis-lab.info/bishop/2011/1 ... tion-plan/
ESRI отказывается от развития ArcInfo Workstation и ArcIMS, переходят от ArcGIS Server Web ADF к API соответствующих компонентов (ArcGIS WebMapping APIs for JavaScript, Flex, Silverlight).
чудны дела твои, Господи ... если мне не изменяет мой склероз, то они поздно спохватились - Silverlight вроде закрыли, Flex - на подходе (разработка прекращена, продукт ушел в open source), про JavaScript - не помню :mrgreen:

Аватара пользователя
Дмитрий Барышников
Гуру
Сообщения: 2572
Зарегистрирован: 17 ноя 2009, 19:17
Репутация: 261
Откуда: Москва

Re: Кто знает VBA?

Сообщение Дмитрий Барышников » 17 ноя 2011, 19:04

JavaScript и HTML5 сейчас основной тренд. Ну еще java наверное.

Аватара пользователя
novia
Гуру
Сообщения: 2261
Зарегистрирован: 29 апр 2011, 15:06
Репутация: 489
Откуда: Тель-Авив

Re: Кто знает VBA?

Сообщение novia » 18 ноя 2011, 08:47

если мне не изменяет мой склероз, то они поздно спохватились - Silverlight вроде закрыли, Flex - на подходе (разработка прекращена, продукт ушел в open source)
с точки зрения разработки под ArcGIS - пока все основные WEB API поддерживаются, о чем недавно написали в ArcGIS Server blog после публикации заявлений Adobe о прекращении развития flash для мобильных браузеров (и переходе на HTML5/Air Mobile).
понравилось? жми палец вверх :!:

KatenoK
Новоприбывший
Сообщения: 13
Зарегистрирован: 16 ноя 2011, 12:40
Репутация: 0

Re: Кто знает VBA?

Сообщение KatenoK » 18 ноя 2011, 10:15

Bishop писал(а):А ведь вслед за Microsoft, ESRI начиная с 10 версии отказалось от VBA - вас учат ненужной технологии!
http://blogs.gis-lab.info/bishop/2011/1 ... tion-plan/
Конечно ненужной! Это все знают, но ничего сделать не могут. Сколько я не поднимала вопрос о том, чтобы нас научили Python, работе в AutoCAD,чертить графики в какой-нибудь проге, а не на милиметровке и т.д. и.т.п. -все бестолку! У нас в беларуси так везде - сикось-накось и всем пофиг. Хорошо, что этот сайт нашла - научусь чему-нибудь полезному :)
Кстати, с заданием я, кажется, разобралась.

gamm
Гуру
Сообщения: 4168
Зарегистрирован: 15 окт 2010, 08:33
Репутация: 1107
Ваше звание: программист
Откуда: Казань

Re: Кто знает VBA?

Сообщение gamm » 18 ноя 2011, 12:16

novia писал(а):после публикации заявлений Adobe о прекращении развития flash для мобильных браузеров
это устаревшая информация - Adobe его вообще перестает поддерживать, а поскольку M$ его и раньше не сильно любила, то скоро под уиндовсом он перестанет работать независимо от желаний ESRI :mrgreen:

Аватара пользователя
Дмитрий Барышников
Гуру
Сообщения: 2572
Зарегистрирован: 17 ноя 2009, 19:17
Репутация: 261
Откуда: Москва

Re: Кто знает VBA?

Сообщение Дмитрий Барышников » 18 ноя 2011, 12:40

Вот еще: http://www.spatiallyadjusted.com/2011/1 ... s-covered/
Порадовало:
So Silverlight, Flash and Flex are dead.
Plus you can use their JavaScript (notice they now append HTML5 to the end?) API to stay “current”

Безликий
Интересующийся
Сообщения: 35
Зарегистрирован: 21 май 2009, 14:11
Репутация: 0

Re: Кто знает VBA?

Сообщение Безликий » 20 ноя 2011, 17:45

KatenoK писал(а):
Bishop писал(а):А ведь вслед за Microsoft, ESRI начиная с 10 версии отказалось от VBA - вас учат ненужной технологии!
http://blogs.gis-lab.info/bishop/2011/1 ... tion-plan/
Конечно ненужной! Это все знают, но ничего сделать не могут. Сколько я не поднимала вопрос о том, чтобы нас научили Python, работе в AutoCAD,чертить графики в какой-нибудь проге, а не на милиметровке и т.д. и.т.п. -все бестолку! У нас в беларуси так везде - сикось-накось и всем пофиг. Хорошо, что этот сайт нашла - научусь чему-нибудь полезному :)
Кстати, с заданием я, кажется, разобралась.
Немного не в тему.
Там с данными технологиями попросту никто не работает. Однако при наличии желания вполне можно попробовать исправить - литературы то достаточно.
Преподам разницы особой нету, начерчено оно рукой или в чём-нибудь. Конечно, при нулевом опыте, времени раз в 8 больше это занимает, но с другой стороны сразу двух зайцев бить.
Сам там учусь, настоятельно рекомендую не ждать с моря погода, а браться за дело.
студент

kog9
Участник
Сообщения: 95
Зарегистрирован: 08 май 2011, 17:34
Репутация: 8
Откуда: Минск

Re: Кто знает VBA?

Сообщение kog9 » 23 ноя 2011, 21:42

Мда оказывается тут много людей из беларуси) я и не догадывался. Полностью согласен с тем что в основном учат нас фигне)

[Сообщение с мобильного устройства] Изображение

Boris
Гуру
Сообщения: 4231
Зарегистрирован: 10 апр 2006, 22:34
Репутация: -344969098
Откуда: Париж

Re: Кто знает VBA?

Сообщение Boris » 24 ноя 2011, 04:45

Ну, если предположить, что ВСЕ выпускники будут работать по профилю, то учитывая место VBA в новых версиях всего на свете, для обучения - не нужен.
Если же предположить более вероятное - 5% будут работать по специальности, 30% уйдут в декрет, остальные как-то будут связаны с парком не самых передовых компьютеров, то знание VBA сможет скрасить чью-то жизнь тем, что будет он/она большим экспертом в написании макросов для Word/Excel и т.п. Что то же является хлебом.

Ответить

Вернуться в «ArcGIS»

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и 1 гость