Обработка данных банков (cbr.ru)

09.11.23

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

Кусок кода для обработки данных(XML) по банкам с сайта cbr.ru. Пойдёт в любую самописку для простенького справочника с банками.
    ЗащищенноеСоединение = Новый ЗащищенноеСоединениеOpenSSL(Неопределено, Неопределено);
    HTTP = Новый HTTPСоединение("www.cbr.ru",,,,,,ЗащищенноеСоединение);
    ХТТПЗапрос = Новый HTTPЗапрос;
    ХТТПЗапрос.АдресРесурса = "/s/newbik";
    HTTP.Получить(ХТТПЗапрос);
    ОтветСервера = HTTP.ВызватьHTTPМетод("GET", ХТТПЗапрос);
    Если ОтветСервера.КодСостояния = 301 Тогда
        АдресРесурса = ОтветСервера.Заголовки.Получить("Location");
        ХТТПЗапрос = Новый HTTPЗапрос;
        ХТТПЗапрос.АдресРесурса = АдресРесурса;
        HTTP.Получить(ХТТПЗапрос);
        ОтветСервера = HTTP.ВызватьHTTPМетод("GET", ХТТПЗапрос);
        Если ОтветСервера.КодСостояния = 200 Тогда
            Ответ = ОтветСервера.ПолучитьТелоКакДвоичныеДанные();
            ФайлДД = ПолучитьИмяВременногоФайла(".zip");
            Ответ.Записать(ФайлДД);
            Архив = Новый ЧтениеZipФайла(ФайлДД);
            Архив.ИзвлечьВсе(КаталогВременныхФайлов(), РежимВосстановленияПутейФайловZIP.Восстанавливать);
            Для Каждого Файл ИЗ Архив.Элементы Цикл
                ПутьКФайлу = КаталогВременныхФайлов() + Файл.Имя;
                Парсер = Новый ЧтениеXML;
                Парсер.ОткрытьФайл(ПутьКФайлу);
                Построитель = Новый ПостроительDOM;
                Документ = Построитель.Прочитать(Парсер);
                Для Каждого Элемент0 Из Документ.ЭлементДокумента.ДочерниеУзлы Цикл
                    Если Элемент0.ИмяУзла = "BICDirectoryEntry" Тогда
                        БИК = Элемент0.Атрибуты.ПолучитьИменованныйЭлемент("BIC").Значение;
                        Для Каждого Элемент1 ИЗ Элемент0.ДочерниеУзлы Цикл
                            Если Элемент1.ИмяУзла = "ParticipantInfo" Тогда
                                НазваниеБанка = Элемент1.Атрибуты.ПолучитьИменованныйЭлемент("NameP").Значение;
                                PtType = Элемент1.Атрибуты.ПолучитьИменованныйЭлемент("PtType").Значение;
                                Закрыт = ?(PtType = "90", Истина, Ложь);
                            ИначеЕсли Элемент1.ИмяУзла = "Accounts" Тогда
                                КоррСчет = Элемент1.Атрибуты.ПолучитьИменованныйЭлемент("Account").Значение;
                            КонецЕсли;
                        КонецЦикла;
                        ДанныеБанка = Новый Структура("БИК, НазваниеБанка, КоррСчет, Закрыт", БИК, НазваниеБанка, КоррСчет, Закрыт);
                        ОбработатьДанные(ДанныеБанка); //Здесь процедура для обработки полученных данных
                    КонецЕсли;
                КонецЦикла;
            КонецЦикла;
        КонецЕсли;
    КонецЕсли;

 

1. Из-за того, что основная ссылка ведёт на страницу с редиректом - получаем два HTTP запроса.

2. Разархивируем полученный файл.

3. Разбираем XML через ПостроительDOM.

Данных в полученном XML файле гораздо больше, чем я получил, но для просто справочника - достаточно.

Соответственно, вот в этой части кода по образу и подобию:

Если Элемент1.ИмяУзла = "ParticipantInfo" Тогда
     НазваниеБанка = Элемент1.Атрибуты.ПолучитьИменованныйЭлемент("NameP").Значение;
     PtType = Элемент1.Атрибуты.ПолучитьИменованныйЭлемент("PtType").Значение;
     Закрыт = ?(PtType = "90", Истина, Ложь);
ИначеЕсли Элемент1.ИмяУзла = "Accounts" Тогда
     КоррСчет = Элемент1.Атрибуты.ПолучитьИменованныйЭлемент("Account").Значение;
КонецЕсли;

добавляем нужные нам атрибуты.

На уникальность и "супер-крутость" кода не претендую:)

Просто решил поделиться, кому-нибудь будет полезно, уверен.

банки xml справочник

См. также

SALE! 20%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 руб.

12.06.2017    144350    837    297    

432

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.20.x), также подходят для релиза 11.5 (11.5.19.x).

35000 руб.

23.07.2020    54595    242    73    

196

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой

55778 50200 руб.

15.04.2019    73379    193    153    

130

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    37724    103    69    

98

SALE! 10%

Перенос данных 1C Взаиморасчеты Оптовая торговля Логистика, склад и ТМЦ Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление торговлей 10 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Управленческий учет Платные (руб)

Можно проверить до покупки, оставьте заявку! Воспользовались более 268 компаний! Перенос данных из УТ 10.3 в УТ 11 | из УТ 10.3 в КА 2 | из УТ 10.3 в ERP. Предлагаем качественное и проверенное временем решение для перехода с УТ 10.3. Можно перенести начальные остатки, нормативно-справочную информацию и все возможные документы. При выгрузке можно установить отбор по периоду, организациям и складам. При выходе новых релизов конфигураций 1C оперативно выпускаем обновление переноса данных.

55778 50200 руб.

24.04.2015    196532    157    244    

287

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.240.x) и БП 3.0 (3.0.169.x). Правила подходят для версии ПРОФ и КОРП.

35000 руб.

15.12.2021    25363    177    52    

135

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Управление производственным предприятием 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

48278 43450 руб.

25.02.2015    172537    309    260    

385

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:ERP Управление предприятием 2.5 и 1С:Комплексную автоматизацию 2.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.240.x), ERP 2.5 (2.5.20.x), КА 2.5 (2.5.20.x), также подходят для релиза ERP 2.5 (2.5.19.x), КА 2.5 (2.5.19.x).

35000 руб.

24.06.2020    64459    79    27    

91
Отзывы
2. user1880116 12.11.23 10:01 Сейчас в теме
(1)
как получить ссылку редиректа
https://httpwg.org/specs/rfc9110.html#status.301

The server SHOULD generate a Location header field in the response containing a preferred URI reference for the new permanent URI. The user agent MAY use the Location field value for automatic redirection.
Остальные комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tsatsur 45 09.11.23 13:58 Сейчас в теме
Если кто-то знает как получить ссылку редиректа (301), подскажите:)
А то:
не по красоте, конечно:))
2. user1880116 12.11.23 10:01 Сейчас в теме
(1)
как получить ссылку редиректа
https://httpwg.org/specs/rfc9110.html#status.301

The server SHOULD generate a Location header field in the response containing a preferred URI reference for the new permanent URI. The user agent MAY use the Location field value for automatic redirection.
3. tsatsur 45 13.11.23 12:59 Сейчас в теме
(2)
server SHOULD generate a Location header field in the response containing a preferred URI reference for the new permanent URI.

Спасибо:) Тупанул. Сейчас поправлю код и обновлю.
Оставьте свое сообщение