Все константы MS Office

09.10.13

Разработка - Инструментарий разработчика

16000+ констант MS Office 2013 для Excel, Word, Access, Outlook, PowerPoint, Project и Visio с краткими описаниями из MSDN, переведены в формат "mxl",
с удобной оболочкой  в виде обработки для отбора и преобразования в другие форматы.
Примеры использования.
Пример получения значений напрямую из Excel (без ВК).

Скачать файлы

Наименование Файл Версия Размер
Все файлы одним архивом
.zip 2,21Mb
158
.zip 2,21Mb 158 Скачать

Предыстория: все, кто программно форматировал документы MS Office из 1С сталкивался с обилием констант, которые там используются. Конечно можно использовать числовые значения и переписывать VBA Help в комментарии, но разобраться иногда становиться непросто, особенно, если писалось давно.
Теоретически, идеально было-бы получать значения констант через точку из того-же COM объекта или функцией Evaluate() или Run(), но для констант это не подходит. Придется использовать родные 1С объекты где есть доступ к свойствам через точку или функции, в которых прописаны все значения. Остается запастить этими значениями на все случаи жизни.

 

1) Обработка MSOEnum.epf - позволяет отметить нужные объекты MS Office и вывести их в макет табличного документа, таблицу значений, структуру или генерировать функцию. Опционально описания констант исключаются.

В макете Табличного Документа используются колонки: Параметр, Значение, Описание.
Значения записываются в именованных областях. Таким образом, можно использовать конструкцию:

1С 8
Значение = ПолучитьМакет("МойМакет").Область("ИмяКонстанты").Значение;

Таблица Значений и Структура выводятся во внутреннем формате - готовые к "закладке" в макеты. Колонки Таблицы Значений: Параметр, Значение, Описание.

В связи с использованием OLE в MS Office - по каждому объекту показано фактически поддерживаемое в нем количество констант. Уникальных констант в итоге меньше на ~1000.

Генерируемая функция совместима с 7.7 и всеми 8.
При генерации макетов "mxl" для 7.7 не забудьте выбрать формат сохранения "Табличный документ v7.7".

2) Обработка ПримерИспользования.epf - для проверки и сравнения методов извлечения.
Из нее можно использовать сводные макеты, минуя предыдущий этап.



Обработка ПримерИспользования.ert - аналогичная предыдущей, для 7.7.
Табличный Документ 8 и Таблица 7.7 оказались наиболее быстрыми объектами на этапе инициализации. У функции единственный недостаток - километр кода.


3) Обработка ДинамическоеВычислениеЗначений.epf - пример вычисления выражений в контексте Excel. Принцип: в Excel создается книга, в которую добавляется и выполняется программный модуль. Для каждого вычисления выполняемая в модуле функция модифицируется.
Требует понижения безопасности до опасного уровня. Только для экспериментов.

 

Практические приёмы (для начинающих).

Для примера возьмем таблицу Excel, в которую данные добавлены программно и нет никакого оформления и выравнивания.
Оформим её вручную, записав все действия в макрос и затем повторим тоже самое из 1С, чтобы убедиться, как это просто и удобно имея таблицу констант.

Исходная таблица


Откроем книгу с данными в Excel сразу включим запись макроса (Вид - Макросы - Запись макроса - ОК)

Вставляем для используемой области таблицу (Вставка - Таблица) или Ctrl + T. В открывшемся конструкторе выбираем стиль, чередование строк, и прочие полезности. Когда в оформлении достигнут желаемый результат - останавливаем макрос (Вид - Макросы - Остановить запись) и забираем код оформления (Макросы - Изменить).
Если потренироваться и под запись не нажимать ничего лишнего код генерируется достаточно чистый.

Результат форматирования


Соответствующий этому форматированию код:

VBA Excel

Sub Макрос1()
'
' Макрос1 Макрос
'

    ActiveSheet.ListObjects.Add(xlSrcRange, Range("$A$1:$J$13"), , xlYes).Name = "Таблица1"
    Range("Таблица1[#All]").Select
    ActiveSheet.ListObjects("Таблица1").TableStyle = "TableStyleLight21"
    ActiveSheet.ListObjects("Таблица1").ShowTotals = False
    ActiveSheet.ListObjects("Таблица1").ShowAutoFilterDropDown = False
    ActiveSheet.ListObjects("Таблица1").ShowTableStyleLastColumn = True
    ActiveSheet.ListObjects("Таблица1").ShowTableStyleColumnStripes = False
    With Selection
        .HorizontalAlignment = xlGeneral
        .VerticalAlignment = xlCenter
        .WrapText = True
        .Orientation = 0
        .AddIndent = False
        .IndentLevel = 0
        .ShrinkToFit = False
        .ReadingOrder = xlContext
        .MergeCells = False
    End With
End Sub


Для адаптации кода в 1С нам нужно указать в параметрах COM объекты, а вместо фиксированной области использовать рабочую "UsedRange" (чтобы получить некоторую универсальность).

1С 8
Процедура КнопкаВыполнитьНажатие(Элемент)
        //Поместим в Структуру константы из макета
    xl = ЗначениеИзСтрокиВнутр( ПолучитьМакет("MSConst_Структура").ПолучитьТекст() );
        //Откроем книгу, выделим используемый диапазон
    Excel = Новый COMОбъект("Excel.Application");
    Excel.DisplayAlerts = Ложь;
    Excel.EnableEvents = Ложь;
    Excel.Workbooks.Open("E:\Книга1.xlsx");
    ActiveSheet = Excel.ActiveSheet;
    ActiveSheet.UsedRange.Select();
        //Тут практически текст VBA. К именам констант дописываем нашу Структуру "xl"
    Таблица1 = ActiveSheet.ListObjects.Add(xl.xlSrcRange, ActiveSheet.UsedRange, , xl.xlYes);
    Таблица1.Name = "Таблица1";
    Таблица1.TableStyle = "TableStyleLight21";
    Таблица1.ShowTotals = False;
    Таблица1.ShowAutoFilterDropDown = False;
    Таблица1.ShowTableStyleLastColumn = True;
    Таблица1.ShowTableStyleColumnStripes = False;
    Excel.Selection.HorizontalAlignment = xl.xlGeneral;
    Excel.Selection.VerticalAlignment = xl.xlCenter;
    Excel.Selection.WrapText = True;
    Excel.Selection.Orientation = 0;
    Excel.Selection.AddIndent = False;
    Excel.Selection.IndentLevel = 0;
    Excel.Selection.ShrinkToFit = False;
    Excel.Selection.ReadingOrder = xl.xlContext;
    Excel.Selection.MergeCells = False;
        //Покажем результат
    Excel.Visible = Истина;
    Excel.DisplayAlerts = Истина;
    Excel.EnableEvents = Истина;
КонецПроцедуры

Сложное форматирование лучше записывать с остановками в несколько макросов, давая им осмысленные имена.
Так будет проще разбираться с кодом, а имена макросов пригодятся для комментариев в 1С.


См. также

SALE! 20%

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

Инструментарий разработчика Роли и права Запросы СКД Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Конфигурации 1cv8 Платные (руб)

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

13000 10400 руб.

02.09.2020    121622    670    389    

711

SALE! 25%

Infostart PrintWizard

Пакетная печать Печатные формы Инструментарий разработчика Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:Конвертация данных 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

18000 15300 руб.

06.10.2023    7263    21    6    

39

SALE! 20%

Infostart УДиФ: Управление данными и формами

Инструменты администратора БД Инструментарий разработчика Роли и права Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

10000 8000 руб.

10.11.2023    3507    11    1    

33

SALE! 30%

PowerTools

Инструментарий разработчика Инструменты администратора БД Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

3600 2520 руб.

14.01.2013    177728    1073    0    

849

Многопоточность. Универсальный «Менеджер потоков» 2.1

Инструментарий разработчика Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    99339    239    97    

296

[ЕХТ] Фреймворк для Расширений 1С

Инструментарий разработчика Платформа 1С v8.3 Управляемые формы Платные (руб)

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в любых Конфигурациях в режиме Управляемого приложения с режимом совместимости 8.3.12 и выше без необходимости внесения изменений в Конфигурацию.

3000 руб.

27.08.2019    18103    6    8    

39

1С HTML Шаблоны / HTML Templates

Инструментарий разработчика Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

2040 руб.

27.12.2017    28096    3    10    

15

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

Инструментарий разработчика Обмен между базами 1C Платформа 1С v8.3 Платные (руб)

В процессе работы в 1С часто возникает потребность получить данные из другой базы.  Обычно это делается через COM-соединение, и время выполнения запроса при этом оставляет желать лучшего. В данной публикации представлено универсальное решение, позволяющее практически моментально выполнить произвольный код или запрос с параметрами в другой информационной базе через Web-сервис.

2400 руб.

24.09.2019    23597    15    15    

32
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. МимохожийОднако 141 24.07.13 06:47 Сейчас в теме
ОК. Получили список констант. Описание и использование каждой константы на русском языке надо брать в справке к Офису или тоже есть где-то в обработке?
2. TrashMaster 196 24.07.13 10:03 Сейчас в теме
Подскажете, где достать - поменяю. Справка пишет "Данное содержимое не доступно на вашем языке, используйте версию на английском...". То, что есть в руссой документации тоже не напрягаются переводить.
Удобнее включить запись макроса, отформатировать документ интерактивно и перекинуть автоматически сгенерированный код в 1с, поправив синтаксис.
Чтобы заменить константу на другую из этого-же набора нужно глянуть соседние строки в макете или в коде макроса VBA в контекстном меню открыть "Definition".
По этому поводу добавил примерчик в описание.
3. ITEkb 26.07.13 08:39 Сейчас в теме
Проходил, знакомо :-)
Спасибо за веселые воспоминания!
4. Арчибальд 2706 26.07.13 10:19 Сейчас в теме
Спасибо,отправлю в мемориз.
5. adhocprog 1139 26.07.13 15:34 Сейчас в теме
Фундаментальный труд )
Стояла такая задача 6 лет назад. Каждый раз вручную смотрел в справке :)
http://infostart.ru/public/163592/
Сриншот № 1.
8. TrashMaster 196 26.07.13 21:13 Сейчас в теме
(5) adhocprog, тоже подобный модуль написал в 03 году, тогда это были просто хиты.
Сейчас снова понадобилось сделать кое-что в excel, но теперь стал ленив - 50 строк кода на парсер и с константами офиса решил закрыть вопрос на все последующие версии.
6. sergnik 26.07.13 17:53 Сейчас в теме
Спасибо за труды) Часто приходится использовать объекты MS Office, замучался гуглить описания)
Опенконф для 7.7 конечно же может сам сгенерить описание всех методов, но очень краткое
7. TrashMaster 196 26.07.13 20:25 Сейчас в теме
(6) sergnik, тут только константы и пример, как заставить офис делать за Вас черную работу. Для остального скачайте себе русскую MSDN и изучейте с комфортом.
9. sick_russian 29.07.13 09:06 Сейчас в теме
Спасибо, возьму на заметку, частенько с ВБА работаю)
10. LexSeIch 210 01.08.13 11:08 Сейчас в теме
Мир этому дому!
Спасибо за информацию. Пока не качал, но взял на заметку. Плюс однозначно.
11. xzorkiix 34 19.08.13 11:29 Сейчас в теме
Спасибо - за проделанное. Познавательно. Написано хорошо.
12. Shrek2015 19.08.13 14:34 Сейчас в теме
познавательно. респект!
13. khizhov 29.08.13 10:33 Сейчас в теме
Спасибо что непожалел сил и труда всё это сделать, будет очень полезно
14. Abadonna 3958 31.08.13 07:36 Сейчас в теме
Мне точно не надо, но работа проделана солидная. Плюс
15. TrashMaster 196 06.09.13 10:56 Сейчас в теме
(14) Abadonna,
Спасибо! Плюс от Мастера удвоил мою карму.

Вскрываю карты, как это делается
16. Поручик 4670 07.09.13 17:02 Сейчас в теме
(0) И другие, кому надо
Список констант Word http://www.progresstalk.com/threads/mail-merge-question.25614/#post-77930
Ещё здесь есть немного http://wladm.narod.ru/Borland/word.html
TrashMaster; +1 Ответить
17. TrashMaster 196 07.09.13 18:49 Сейчас в теме
(16) Поручик,
1) В Word за 16 лет количество констант удвоилось. Сам сначала попробовал использовать функцию с мисты, но не поперло.
2) OlePropertyGet - надо вызывать в контекстах соответствующих объектов (может ошибаюсь), а их немало. Но можно и так.
Вопрос в удобстве. Выйдет следующая версия офиса - а парсер msdn уже выложен http://infostart.ru/public/200004/ нажал кнопку, и готово - пошел делать что-нибудь другое.
18. Поручик 4670 07.09.13 19:43 Сейчас в теме
(17) Для большинства приложений в 1С сгодится и такой список. В самом деле, что в основном генерят из 1С для Word и Excel? Относительно несложный документ или таблицу и немного стилевого оформления абзацев или ячеек, то есть применяются константы цветов, шрифтов и выравнивания абзацев.
19. TrashMaster 196 07.09.13 20:08 Сейчас в теме
(18) Поручик, Согласен, но неприятно, когда в нем чего-то не хватает. Для надежность лучше иметь 100%.
Бывает, ещё всякая хрень нужна:
20. NAKIS 5 18.12.13 12:05 Сейчас в теме
Спасибо)) очень полезно)
21. Патриот 450 24.11.14 13:39 Сейчас в теме
Однозначно плюс! Раньше приходилось каждую константу в справке смотреть, теперь не надо, и к тому же код будет наряднее, когда вместо цифры имя константы будет.
Оставьте свое сообщение