Форум программистов, компьютерный форум, киберфорум
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. Показов 5702. Ответов 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)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
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
4080 / 1460 / 401
Регистрация: 07.08.2013
Сообщений: 3,651
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
4080 / 1460 / 401
Регистрация: 07.08.2013
Сообщений: 3,651
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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
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
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru