С Новым годом! Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.79/29: Рейтинг темы: голосов - 29, средняя оценка - 4.79
2 / 2 / 1
Регистрация: 23.03.2015
Сообщений: 78
1

Работа с excel из outlook. Library not registered

20.03.2019, 07:20. Показов 5744. Ответов 9
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день.
Возникла задача формировать таблицу excel из макроса outlook.
Оба приложения установлены одновременно из одного дистрибутива msOffice 2010, установлен sp1.
Без подключения объектной библиотеки excel (tools > references, microsoft excel 14.0 object library) не работает раннее связывание и среда ругается на такие сложные вещи, как range. Cells при этом понимает ).
Если подключить библиотеку - возникает ошибка "Automation error. Library not registered".

Ошибка возникает, например на 2 строе этого кода:
Visual Basic
1
2
dim xlApp as excel.application
set xlApp = CreateObject("excel.application")
Как это лечить?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
20.03.2019, 07:20
Ответы с готовыми решениями:

Object library not registered
Добрый день!Возникла проблема при подключении Microsoft Windows Common Controls 2 6.0 sp 6...

IIS ошибка: error '8002801d' Library not registered. /stat.asp, line 5
Перестал работать IIS. Вообще. При попытке обращения к любому стандартному объекту (ну типа Server...

Запрос через Outlook, обработка в Excel, ответ через Outlook
Уважаемые VB & VBA_ програмисты! Насколько возможно реализовать следующую задачу, домашними ...

Зависимость от Microsoft Excel Object Library
Всем привет! Помогите недостойному разобраться с Excel Вот я подключил библиотеку...

9
4082 / 1462 / 401
Регистрация: 07.08.2013
Сообщений: 3,657
20.03.2019, 08:24 2
Visual Basic
1
dim xlApp as object
так раннее связывание и предполагает что библиотека уже подключена (принудительно руками)
а вот позднее связывание не предполагает что библиотека подключена
что лучше - тут много про это уже сказано
по мне так ...
в процессе разработки кода подключить библиотеку
а при передаче в эксплуатацию переделать код на позднее связывание

Добавлено через 9 минут
и аккуратнее с префиксом xl в переменных
Excel этот префикс использует для обозначения своих констант
1
2 / 2 / 1
Регистрация: 23.03.2015
Сообщений: 78
20.03.2019, 09:15  [ТС] 3
snipe, подскажите, как в тексте макроса outlook подключить библиотеку экселя!
Поставить галочку в referenses, походу, на моем компе недостаточно (win10 + office 2010). Хотя у коллеги с win7 ошибка пропадает.
PS про префикс спасибо, учту!
0
4082 / 1462 / 401
Регистрация: 07.08.2013
Сообщений: 3,657
20.03.2019, 10:08 4
может все таки excel криво стоит
0
2 / 2 / 1
Регистрация: 23.03.2015
Сообщений: 78
20.03.2019, 12:27  [ТС] 5
snipe, тоже об этом подумал. Изначально было win10_x64 + office 2010_x86.
переустановил этот же офис - не помогло, поставил office 2010_x64 - не помогло. Установка sp2 в обоих случаях так же не повлияла. Другие версии офиса ставить не могу.
Скрипт валится в ошибку "библиотека не зарегистрирована".
может есть возможность как-то ее перегистриировать?

зы. как альтернатива - можно попробовать отключить либу и полностью объявлять все методы... но там тоже для меня есть непонятки.
Visual Basic
1
2
3
Set xlApp = CreateObject("Excel.Application")
Set xlWbRep = xlApp.Workbooks.Open("d:\monitoring.xlsx")
xlApp.xlWbRep.worksheets("Лист1").range(cells(3, iFCol), cells(45, iFCol + 5)).Clear
в этом коде среда не понимает слово cells.
Как это написать корректно?
0
4135 / 2239 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
20.03.2019, 12:33 6
Цитата Сообщение от bonanza Посмотреть сообщение
в этом коде среда не понимает слово cells.
Нужно просто явно указать родителя, т.е.

Visual Basic
1
2
3
4
5
Set xlApp = CreateObject("Excel.Application")
Set xlWbRep = xlApp.Workbooks.Open("d:\monitoring.xlsx")
With xlApp.xlWbRep.Worksheets("Лист1")
     .Range(.Cells(3, iFCol), .Cells(45, iFCol + 5)).Clear
End With
1
2 / 2 / 1
Регистрация: 23.03.2015
Сообщений: 78
20.03.2019, 12:48  [ТС] 7
это я уже пробовал.
на строке With xlApp.xlWbRep.Worksheets("Лист1") скрипт падает с ошибкой "object doesnt support this property or method"
0
4135 / 2239 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
20.03.2019, 13:03 8
Лучший ответ Сообщение было отмечено bonanza как решение

Решение

Сорри, за копирование Ваших ошибок

Visual Basic
1
With xlWbRep.Worksheets("Лист1")
или

Visual Basic
1
With xlApp.Workbooks("Monitoring.xlsx").Worksheets("Лист1")
1
2 / 2 / 1
Регистрация: 23.03.2015
Сообщений: 78
20.03.2019, 16:07  [ТС] 9
pashulka, спасибо, завтра попробую.
Похоже беда с либой связана с доменными политиками, а значит в нашем случае неизлечима )
А можете объяснить теоретическую разницу между моей кривой конструкцией и предложенными Вами вариантами? Ну так, для моего общего развития ))
0
4135 / 2239 / 940
Регистрация: 01.12.2010
Сообщений: 4,624
21.03.2019, 07:34 10
bonanza, На официальном сайте можно найти статью о необходимости явно указывать родителя и для Cells

Excel automation fails second time code runs
1
21.03.2019, 07:34
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.03.2019, 07:34
Помогаю со студенческими работами здесь

Помогите с Excel 9.0 Object Library и Oficce 97
Уважаемые господа. Помогите разобраться !!! Проект готов к установке на других комьютерах,но вот...

Использование Microsoft Excel 9.0 Object Library (VB.NET)
При попытке добавить новый Worksheet (.Application.Worksheets.Add()) выдаётся сообщение об ошибке...

Написание программы с применением билиотеки microsoft excel 10.0 object library
Пишу программу с применением билиотеки microsoft excel 10.0 object library. Эта библиотека - файл...

Excel из Outlook
Продолжаю наскоком разбираться с VBA Хочу по приходу письма занести в таблицу xl имя отправителя....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Как проводить научные вычисления на Python
InfoMaster 15.01.2025
Python стал одним из наиболее востребованных языков программирования в области научных вычислений благодаря своей простоте, гибкости и обширной экосистеме специализированных библиотек. Научные. . .
Создание игры типа Minecraft на PyGame/Python: пошаговое руководство
InfoMaster 15.01.2025
В данном руководстве мы рассмотрим процесс создания игры в стиле Minecraft с использованием библиотеки PyGame на языке программирования Python. Этот проект идеально подходит как для начинающих. . .
Как создать свою первую игру в стиле Doom на Unreal Engine
InfoMaster 15.01.2025
Разработка шутера от первого лица в стиле классического Doom представляет собой увлекательное путешествие в мир игрового программирования, где сочетаются творческий подход и технические навыки. . . .
Параллельное программировани­е: основные технологии и принципы
InfoMaster 15.01.2025
Введение в параллельное программирование Параллельное программирование представляет собой фундаментальный подход к разработке программного обеспечения, который позволяет одновременно выполнять. . .
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru