Определение района по адресу

06.02.18

Интеграция - WEB-интеграция

Расширение для определения района по ФИАС.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Расширение для конфигурации "Библиотека стандартных подсистем" редакции 2.4, платформа 8.3.12.1249:
.cfe 59,16Kb ver:1.0.0
17 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

   Периодически возникает задача определения района города по адресу (например, для распределения заказов между курьерами). Под районом подразумевается многоугольник, описанный координатами вершин. Рассмотрим пример решения данной задачи для г. Иркутска (для другого города нужно изменить координаты в макетах и отборы в запросе), конфигурация "Библиотека стандартных подсистем" редакции 2.4 (режим совместимости "Не использовать", тонкий клиент) с использованием API Яндекс карт. Следует отметить, что в данной конфигурации (как и в большинстве типовых "нового" поколения) используется ФИАС.

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

Создание района
(1 - создание нового многоугольника, 2 - заполнение таблицы координат вершин по данным на карте).

     Теперь нужно определиться с тем, как именно определять координаты по адресу - возможны следующие варианты: геокодирование адреса каждого дома, геокодирование родительских объектов (улиц, населенных пунктов и т.д.). Реализовать первый вариант можно с помощью сервиса Dadata.ru. Для второго варианта в качестве координаты можно брать середину объекта и уточнять при необходимости диапазоном номеров домов, при этом следует иметь ввиду сложные по структуре улицы. По точности оба варианта имеют погрешности: для дома - ошибки задания номера, неактуальность базы, ошибки геокодирования; для улиц - при сложной структуре часть домов может попадать в разные районы. Реализуем второй вариант - составим текстовое представление адреса (без домов) и получим для каждого координаты середины:

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

Аналогичный пример для КЛАДР можно посмотреть по этой ссылке.

P.S.: Данная публикация описывает личное мнение. Конструктивная критика приветствуется. Опечатки просьба отправлять в личном сообщении.

Вступайте в нашу телеграмм-группу Инфостарт

Адрес район Яндекс карты ФИАС

См. также

WEB-интеграция Программист Бизнес-аналитик 1С:Предприятие 8 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Оптовая торговля, дистрибуция, логистика ИТ-компания Платные (руб)

Модуль "Экспортер" — это расширение для 1С, предназначенное для автоматизации процессов выгрузки данных. Оно позволяет эффективно извлекать, преобразовывать и передавать данные из систем 1С в интеграционную платформу Spot2D. Подсистема упрощает настройку, снижает количество ручных операций и обеспечивает удобный контроль данных.

17568 руб.

20.12.2024    6530    28    4    

30

WEB-интеграция Программист 1С:Предприятие 8 1С:Бухгалтерия 3.0 Бытовые услуги, сервис Платные (руб)

Расширение для автоматизации передачи данных между сервисом Vetmanager с 1С: Бухгалтерия 3.0. Решение позволяет загружать документы и справочники из Ветменеджер в 1С:Бухгалтерию, сокращая время на ручной ввод данных и минимизируя ошибки.

24000 руб.

02.02.2021    23296    70    52    

43

Сайты и интернет-магазины WEB-интеграция Системный администратор Программист Пользователь 1С:Предприятие 8 1C:Бухгалтерия 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM / LOGICSTARS. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM / LOGICSTAR разных брендов в одной информационной базе в ручном и автоматическом режиме.

42700 руб.

03.08.2020    24576    37    26    

28

WEB-интеграция Системный администратор Программист Пользователь 1С:Предприятие 8 1C:Бухгалтерия 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена по API между конфигурацией 1С:Альфа-Авто 6 и порталом LogicStar. Позволяет работать с несколькими обменами LogicStar разных брендов (CHERY, OMODA, JAECOO, EXEED, TENET) в одной информационной базе в ручном и автоматическом режиме. Поддерживается выгрузка заказ-нарядов, реализаций товаров и товарных остатков.

20740 руб.

13.05.2025    2297    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. top_1c 4108 07.02.18 05:46 Сейчас в теме
Опять наш Иркутск, вы с коллегой не с одного цеха? https://infostart.ru/public/725116/
3. CSiER 36 07.02.18 07:07 Сейчас в теме
(1), ранее работал в организации, в которой сейчас работает автор указанной публикации.
2. kuzyara 2255 07.02.18 06:55 Сейчас в теме
Плюсану соотечественнику)
top_1c; CSiER; +2 Ответить
4. d.zhukov 1646 08.02.18 10:46 Сейчас в теме
Привет, Иркутяне) тоже недавно заморачивались подобной задачей) В Иркутске видать вопрос по транспортной логистике стоит остро))
5. V.Nikonov 126 13.02.18 18:04 Сейчас в теме
Геокодирование по Улицам будет кошмарным в случае наличия длинных улиц. Корректнее хранить Геокоординаты в объектах и править их с участием пользователя. Для первичного контроля можно вычислять расстояние между точками полученными для середины улицы и с указанием дома, при значительных расхождения просить вмешаться пользователя...
6. CSiER 36 14.02.18 03:07 Сейчас в теме
(5)
Геокодирование по Улицам будет кошмарным в случае наличия длинных улиц.

именно поэтому добавлено разделение по диапазонам домов. Про правку пользователями в случае хранения координат для каждого объекта вопрос спорный - слишком много ручной работы (только МКД около 8000). В то же время проверить привязку примерно 2000 улиц реально. Дополнительно, данные по домам нужно актуализировать намного чаще, чем по улицам.
По опыту, из всех опробованных вариантов (определение принадлежности дома к району через 2GIS, Dadata, Яндекс, OSM / привязка к улицам) самым "рабочим" оказался вариант с улицами.
(5)
Для первичного контроля можно вычислять расстояние между точками полученными для середины улицы и с указанием дома, при значительных расхождения просить вмешаться пользователя...
- хорошая идея. В рамках определения района по улицам можно проверять максимальный, минимальный и несколько промежуточных номеров домов. К сожалению, даже с такими проверками нужна ручная правка.
Все описанное относится к г. Иркутску.
Для отправки сообщения требуется регистрация/авторизация