Libreoffice не работают макросы excel

Обновлено: 04.07.2024

Чаще всего, макрос это сохранённая последовательность команд или нажатий клавиш, предназначенная для последующего использования. Например, можно сохранить и «впечатывать» свой адрес. Язык программирования LibreOffice очень гибок и позволяет автоматизировать как простые, так и сложные задачи. Макросы часто используются, когда мы хотим повторять ещё и ещё раз определённую последовательность действий в схожих условиях.

Макросы в LibreOffice обычно записываются на языке, называемом LibreOffice Basic или просто Basic. Конечно можно долго изучить Basic и наконец начать программировать, но это руководство поможет вам сразу решать простые задачи. Начинающие пользователи часто с успехом применяют макросы, написанные кем-либо другим. Также, можно использовать функцию записи макросов, чтобы сохранить последовательность нажатий клавиш и использовать её ещё раз.

Большинство действий в LibreOffice выполняются путём отправки команды (посылки команды, dispatching a command), которая перехватывается и выполняется. Функция записи макросов позволяет записать непосредственные команды, которые обрабатываются (смотрите Платформа диспетчера).

Ваш первый макрос¶

Добавление макроса¶

Первый шаг в изучении программирования макросов, это найти и использовать существующие макросы. В этом разделе подразумевается, что у вас уже имеется макрос, который вы хотите использовать. Вы могли найти его в Интернете или в какой-нибудь книге. Рассмотрим пример 1. Чтобы записать этот макрос, вы должны предварительно создать библиотеку и модуль, и уже в модуле написать текст макроса, смотрите Организация макросов.

Чтобы создать библиотеку, необходимо выполнить следующие шаги:

  1. Выберете пункты главного меню Сервис ‣ Макросы ‣ Управление макросами ‣ LibreOffice Basic , чтобы открыть диалог работы с макросами Libreoffice Basic.

Диалог работы с макросами LibreOffice Basic

Диалог работы с макросами LibreOffice Basic

  1. Нажмите Управление, чтобы открыть диалог организатора макросов и выберите вкладку Библиотеки.
  2. Выберите в выпадающем списке Приложение/Документ пункт Мои макросы и диалоги.

Диалог организатора макросов LibreOffice Basic

Диалог организатора макросов LibreOffice Basic

  1. Нажмите Создать, чтобы открыть диалог создания новой библиотеки.
  2. Введите имя библиотеки, например, TestLibrary и нажмите OK.
  3. Выберите вкладку Модули.
  4. В списке модулей раскройте Мои макросы и выберите TestLibrary. Модуль с именем Module1 уже существует, он может содержать ваши макросы. Если необходимо, том можно нажать Создать, чтобы создать другой модуль в библиотеке.
  5. Выберите Module1 или новый модуль, который вы создали и нажмите Правка, чтобы открыть интегрированную среду разработки (IDE). Интегрированная среда разработки это текстовый редактор, включённый в LibreOffice, который позволяет создавать и редактировать макросы.

Интегрированная среда разработки макросов

Интегрированная среда разработки макросов

  1. После создания нового модуля он содержит комментарий и пустой макрос, названный Main, который ничего не делает.
  2. Добавьте новый макрос или до Sub Main или после End Sub . В примере ниже приведен новый макрос, который был добавлен до Sub Main .

Пример 2: Module1 после добавления нового макроса:

  1. Нажмите на значок Компилировать на панели инструментов, чтобы откомпилировать макрос.
  1. Поставьте курсор в процедуру HelloMacro и нажмите на значок Выполнить BASIC на панели инструментов или нажмите клавишу F5 , чтобы выполнить HelloMacro в модуле. Откроется маленький диалог со словом Привет . Если курсор не находится внутри процедуры Sub или функции Function , откроется диалог выбора макроса для запуска.
  1. Нажмите OK, чтобы закрыть диалог.
  2. Чтобы выбрать и выполнить любой макрос в данном модуле, нажмите значок Выбрать макрос на стандартной панели инструментов или выберите Сервис ‣ Макросы ‣ Управление макросами ‣ LibreOffice Basic .
  1. Выберите макрос и нажмите Выполнить.

Запись макросов¶

Если вы хотите многократно ввести одинаковую информацию, вы можете скопировать эту информацию после того, как она введена в первый раз, затем вставлять эту информацию в ваш документ каждый раз по мере необходимости. Однако, если вы скопировали в буфер обмена что-то ещё, содержимое буфера меняется. Это означает, что вы должны заново скопировать вашу повторяющуюся информацию. Чтобы обойти эту проблему, вы можете создать макрос, который в процессе выполнения вводит нужную вам информацию.

Для некоторых типов многократно вводимой в документах информации более удобно создать файл автотекста. Описание работы с автотекстом смотрите в справочной системе и в главе Глава 3 – Использование Стилей и Шаблонов данного руководства.

  1. Убедитесь, что функция записи макросов активизирована, выбрав Сервис ‣ Параметры ‣ LibreOffice ‣ Расширенные возможности . Установите флажок Включить запись макросов. По умолчанию эта функция отключена, когда LibreOffice впервые установлен на ваш компьютер.
  2. Выберите Сервис ‣ Макросы ‣ Записать макрос из главного меню, чтобы запустить запись макроса. Появится маленький диалог, подтверждающий, что LibreOffice записывает ваши действия.

Диалог записи макроса

Диалог записи макроса

  1. Наберите желаемую информацию или выполните необходимые действия. Например, напечатайте ваше имя.
  2. Нажмите Завершить запись в маленьком диалоге, чтобы остановить запись, и появится диалог работы с макросами LibreOffice.
  3. Откройте библиотечный контейнер Мои макросы.
  4. Найдите библиотеку с именем Standard в Моих макросах. Обратите внимание, что каждый библиотечный контейнер содержит библиотеку Standard .
  5. Выберите библиотеку Standard и нажмите Создать модуль, чтобы создать новый модуль, содержащий макросы. Откроется диалог создания модуля.

Диалог создания модуля

Диалог создания модуля

  1. Задайте название для нового модуля, например, Recorded и нажмите OK, чтобы создать модуль. В диалоге работы с макросами теперь виден этот новый модуль в составе библиотеки Standard .
  2. В поле Имя макроса напечатайте имя для макроса, который вы только что записали, например, EnterMyName .
  3. Нажмите Записать, чтобы сохранить макрос и закрыть диалог работы с макросами.
  4. Если вы верно выполнили все шаги, описанные выше, библиотека Standard теперь содержит модуль Recorded , и этот модуль содержит макрос EnterMyName .

Когда LibreOffice создаёт новый модуль, в этот модуль автоматически добавляется процедура с именем Main .

Запуск макроса¶

  1. Выберите Сервис ‣ Макросы ‣ Выполнить макрос , чтобы открыть диалог выбора макроса.
  2. Например, выберите ваш только что созданный макрос EnterMyName и нажмите Выполнить.
  3. Можно также вызвать из главного меню Сервис ‣ Макросы ‣ Управление макросами ‣ LibreOffice Basic , чтобы открыть диалог работы с макросами, выбрать ваш макрос и нажать Выполнить.

Диалог выбора макроса

Диалог выбора макроса

Просмотр и редактирование макросов¶

Чтобы просмотреть или отредактировать созданные вами макросы выполните:

  1. Сервис ‣ Макросы ‣ Управление макросами ‣ LibreOffice Basic , чтобы открыть диалог работы с макросами.
  2. Выберите ваш новый макрос EnterMyName и нажмите Правка, чтобы открыть макрос в интегрированной среде разработки.

Макрос EnterMyName не так уж сложен, как может показаться. Изучение нескольких вещей существенно поможет в понимании макросов. Начнём сначала и посмотрим на самую первую строку примера.

Макрос EnterMyName не так уж сложен, как может показаться. Изучение нескольких вещей существенно поможет в понимании макросов. Начнём сначала и посмотрим на самую первую строку примера.

Пример 3: Сгенерированный макрос EnterMyname :

Комментарии¶

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

Все комментарии в макросах начинаются с ключевого слова REM . Весь текст строки после REM игнорируется компьютером при выполнении макроса. Можно также использовать символ одинарной кавычки ( ' ), чтобы начать комментарий.

Ключевые слова в LibreOffice Basic могут быть записаны в любом регистре, таким образом REM , Rem , и rem могут начинать комментарий. Если вы используете символические константы, определяемые в программном интерфейсе приложения (Application Programming Interface, API), безопаснее считать, что имена чувствительны к регистру. Символические константы не описаны в данном руководстве, они не нужны, когда вы используете функцию записи макросов в LibreOffice.

Определение процедур¶

Отдельные макросы сохраняются в процедурах, которые начинаются с ключевого слова SUB . Окончание процедуры обозначается END SUB . Код модуля в примере 3 начинается с определения процедуры, названной Main, в которой нет ничего, и она ничего не делает. Следующая процедура, EnterMyName , содержит сгенерированный код вашего макроса.

Когда LibreOffice создаёт новый модуль, в этот модуль всегда автоматически добавляется процедура с именем Main .

Существует много полезной информации, не вошедшей в данное руководство, однако знание о ней весьма интересно:

Определение переменных¶

Вы можете записать информацию на листе бумаги и позднее воспользоваться этой информацией. Переменные, подобно листу бумаги, содержат информацию, которую можно изменять или читать. Ключевое слово Dim используется для описания типа переменной и для задания размерности массивов. Оператор dim в макросе EnterMyName используется подобно подготовке листа бумаги для записи информации.

В макросе EnterMyName переменные document и dispatcher определены с типом object (объект). Другие часто используемые типы переменных включают string (строка), integer (целое) и date (дата). Третья переменная с именем args1 – это массив значений свойств. Массивы это переменные, содержащие несколько величин, подобно тому, как в одной книге содержится несколько страниц. Величины в массивах обычно нумеруются начиная с нуля. Число в скобках задаёт максимальный номер, используемый для доступа к элементу массива. В данном примере в массиве содержится только одна величина, и она имеет номер ноль.

Как это работает¶

Разберёмся более подробно с кодом макроса EnterMyName . Может быть вы и не поймёте всех тонкостей, но разбор каждой строки в коде позволит вам осознать то, как работают макросы.

Я недавно перешел на pclinuxos из окон, и мне это нравится. Единственная проблема, с которой я столкнулся, заключается в том, что libreoffice, пакет электронных таблиц по умолчанию, несовместим с макросами Excel. Ниже приведен код vba, который у меня есть:

Есть ли способ преобразовать этот код, чтобы сделать его совместимым с libreoffice, или мне нужно выучить совершенно новый язык, например python? Изучение python не будет проблемой, но не является решением моей проблемы, поскольку у меня есть много файлов, связанных с работой, в excel, которые содержат много кода vba, и я не могу использовать открытый офис / libreoffice на работе .

Вы должны перевести части, которые управляют документом, чтобы использовать UNO API. К сожалению, это может быть сложно в зависимости от того, что делает ваш макрос. Основные утверждения работают напрямую. Как правило, при изменении документа этого не происходит.

Команда Cells возвращает определенную ячейку на основе строки и столбца. Итак, вам нужна текущая строка. Вот какое безумие получить активную ячейку:

Когда у вас есть активная ячейка, вы получаете адрес ячейки, а из него - строку. Вам вообще не нужно использовать диапазон, поскольку вас интересует только одна ячейка, поэтому вы получаете активный лист, а затем получаете конкретную ячейку из листа.

Примерно так: ThisComponent.getCurrentController (). GetActiveSheet (). GetCellByPosition (nCol, nRow) .getString () = "a"

Я не хочу разбираться в том, что это делает

Из файла интерактивной справки LibreOffice:

За некоторыми исключениями, Microsoft Office и LibreOffice не могут запускать один и тот же код макроса. Microsoft Office использует код VBA (Visual Basic для приложений), а LibreOffice использует код Basic, основанный на среде LibreOffice API (интерфейс прикладных программ). Хотя язык программирования тот же, объекты и методы разные.

Самые последние версии LibreOffice могут запускать некоторые сценарии Excel Visual Basic, если вы включите эту функцию в LibreOffice - PreferencesTools - Параметры - Загрузить / Сохранить - Свойства VBA.

На самом деле вам, скорее всего, придется сесть за LibreOffice API. и перепишем функционал.

Единственный автоматический инструмент, о котором я знаю, - это бизнес-таблицы (обратите внимание, что у меня нет личных или профессиональный опыт, или какое-либо отношение к сайту).

Это похоже на OpenOffice, но я думаю, что он работает и с LibreOffice.

В общем, лучше сделать это самому, инструмент далек от совершенства .

В LibreOffice 4.4 первая подпрограмма не будет работать вообще (я подозреваю, что все переменные начинаются с 'xl'. Две другие работают отлично, если вы измените ThisCell на ActiveCell.

Для этих целей есть специальная версия Portable: ftp://ftp/SPO/LibreOffice/Portable/
Установщик этой версии просто создаст папку с носимой версией LibreOffice. Эту папку нужно скопировать на карту памяти и запускать прямо с неё.

  • Я открываю файл из приложения, но ничего не происходит.
  • В свойствах документа не указывается автор, почему?

Поскольку LibreOffice продукт кроссплатформенный, он не берёт информацию об авторе из операционной системы. Нужно заполнить параметры автора в меню «Сервис»→«Параметры» во вкладке «LibreOffice»→«Сведения о пользователе». Не обязательно заполнять все поля, но, как минимум, ФИО и организацию следует заполнить. Также рекомендуется заполнить и контактную информацию, такую как e-mail и телефон.

  • Периодически возникают проблемы с открытием файла: пустое окно, полосы на тексте, другие артефакты.
  • Зайти в меню «Сервис»→«Параметры. »
  • В разделе «LibreOffice»→«Вид» снять установленную опцию «Весь вывод при помощи OpenGL» , возможно потребуется отключить опцию «Аппаратное ускорение»
  • У меня сейчас файлы tiff (jpeg,gif, и.т.п.) открываются в LibreOffice Draw и с ними невозможно работать.

Программа LibreOffice Draw, это редактор векторной графики, и он предназначен для другого. Не следует назначать программы из пакета LibreOffice для открытия по умолчанию абсолютно всех типов документов. Тот же tiff лучше открывать просмотром фотографий Windows или другими просмотрщиками, специально предназначенными для этого.

  • Я загружаю документ на сайт или отправляю по электронной почте, но принимающая сторона не принимает формат ODF, как быть?
  • Я отправляю файл в формате MS Office, но всё равно у получателя возникают проблемы с его открытием. В каком вообще формате лучше сохранять файлы, чтобы избежать проблем совместимости?
  • О совместной работе с MS Office, если он установлен на вашем компьютере

Если у вас на компьютере установлен MS Office, может так получиться, что часть документов открываются в MS Office, а другая часть - в LibreOffice. В этом случае Вы обязательно столкнётесь с проблемой, при попытке копирования данных из одного офиса в другой. Чтобы этих проблем не было, нужно открывать все документы в LbreOffice. Учтите, что не смотря на декларирование совместимости с Open Document, на деле MS Office поддерживает этот стандарт плохо, поэтому, для одновременной работы с документами в различных форматах, открывать их нужно именно в LibreOffice.

  • Как заставить работать макросы MS Office в LibreOffice?
  • LibreOffice неожиданно закрывается без сохранения данных. Восстановление документов не помогает.
  1. ошибка библиотеки MSVC, которая проявляется под Windows 7. Для начала, следует переустановить библиотеку. ftp://ftp/SPO/LibreOffice/TroubleSooting/
  2. Также может помочь отключение OpenGL, как это описано выше.
  • Как напечатать документ нажатием одной кнопки, чтобы не вызывалось окно параметров печати?

Кнопка непосредственной печати по умолчанию скрыта. Чтобы показать нужную кнопку, нужно кликнуть по панели инструментов (можно по кнопке «Печать») правой кнопкой мыши и выбрать из меню «Показать кнопки» показ кнопки «Печать непосредственно». Эта настройка активируется отдельно для каждого приложения, т.к. панели инструментов у каждого свои.

Работа с Directum¶

  • При копировании ссылки из Directum она отображается кракозябрами

По умолчанию, при копировании, текст вставляется в формате RTF. Очевидно, текст берётся из Directum не совсем корректно — с неверной кодировкой. Если вставлять в формате HTML, через меню «Вставить как», то ссылка будет вставлена как нужно.

  • Почему не открывается одновременно два документа из Directum?
    При попытке открыть второй документ, он открывается сам после того, как я закрою первый. Если попытаться открыть несколько документов, то получается целая «карусель»
  • Зайти в меню «Сервис» → «Параметры. »
  • В разделе «LibreOffice» → «Память» установить опцию «Запускать LibreOffice во время запуска системы».
  • После закрытия документа в LibreOffice, Directum не даёт повторно открыть его на редактирование.

Поможет установка опции «Запускать LibreOffice во время запуска системы», как описано выше. (Это официальная рекомендация техподдержки Directum)

  • Я открываю на редактирование из Directum документ в формате RTF/DOC/DOCX. Как сохранить его в Directum в формате ODT (расширение odt, ods и т. п.)?

Для этого нужно этот документ сохранить с новым именем локально, а затем создать новую версию и загрузить из файла. Для этого нужно на документе в Directum кликнуть правой кнопкой и выбрать «Импортировать»→«Из файла», а затем загрузить новую версию из локального файла.

Копирование и вставка¶

  • Как вставить в LibreOffice объект, чтобы он открывался по двойному щелчку в соответствующем приложении.

«Вставка→Объект→Объект OLE. ». Далее нужно выбрать тип объекта «Дополнительные объекты» и в открывшемся диалоге выбрать «создать из файла». Галку «в виде значка» устанавливать не нужно. При этом, вставленный объект будет нормально виден в MS Office, но, если файл сохранить в MS Office, для LibreOffice объекты будут потеряны.

  • Я копирую данные из MS Office, и у меня съезжает всё форматирование. Копирование занимает очень много времени

Не следует копировать данные из одного приложения в другое. Следует открыть все нужные файлы в LibreOffice и все действия выполнять в нём.

Печать¶

  • Как напечатать в файл формате PDF?

Через меню «Файл»→«Экспорт в PDF». Если необходимо выпустить документ для длительного хранения, нужно установить опцию «PDF/A»

  • Напечатать файл с примечаниями?

Через меню «Файл»→«Печать. », выбрать нужную опцию в выпадающем списке «Примечания».

Работа конвертеров основана на макрокомандах (макросах). Обычно макросы применяют для выполнения рутинных действий. Мы же будем использовать их для формирования файлов в ИФНС.

По умолчанию использование макросов отключено в Excel и LibreOffice Calc. Нужно самостоятельно один раз включить их. Сделать это очень легко.

Щелкаем на кнопку Файл в левом верхнем углу и выбираем Параметры в открывшемся меню:

macro1

В появившемся диалоговом окне выбираем Центр управления безопасностью и Параметры центра управления безопасностью.

macro2

macro3

Подтвердите свой выбор, нажатием ОК во всех открытых диалоговых окнах.

После этого вам также необходимо закрыть и открыть файл Excel, чтобы изменения вступили в силу. В дальнейшем макросы будут запускаться в Excel 2007 автоматически.

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

После установки откройте программу Calc. В меню Сервис выбираем Параметры.

macro1-1

Выбираем пункт Безопасность и нажимаем на кнопку Безопасн. макросов

macro2-1

Выбираем уровень Средний (в этом случае при запуске макроса нужно подтверждать его работу дополнительным нажатием на кнопку) или Низкий.

macro3-1

Подтвердите свой выбор, нажатием ОК во всех открытых диалоговых окнах.

Конвертер уведомления о контролируемых сделках - Конвертер обновлен до версии 5.04 отчетность за 2019г. !

Конвертер уведомления о контролируемых сделках - Добавлен импорт данных из формата 5.01 (до 2018) и 5.03 (после 2018г.) !

Мы восстановили возможность производить покупку он-лайн через сервис Робокасса. Оплачивайте конвертеры и получайте ссылку для скачивания самых новых версий!

Теперь подтвердить экспорт можно с помощью Конвертера реестра подтверждения экспорта. Как и все наши продукты этот конвертер поможет Вам эффективно использовать время при составлении декларации по НДС.

Заполнить декларацию по НДС за 1 квартал 2016г. помогут актуальные версии конвертеров. Мы по прежнему продолжаем поддержку всех наших клиентов во время декларационной компании.

Декларационная кампания за 4 квартал 2015г. - все версии конвертеров по прежнему актуальны и могут быть использованы для сдачи отчета. Последние версии конвертеров - самые удобные для использования.

19 июля появилась возможность формировать книги покупок и продаж для загрузки в Налогоплательщик ЮЛ напрямую (не через декларацию).

31 мая обновлены конвертеры для формирования декларации по НДС. Об изменениях можно прочитать здесь.

За декларационную компанию за 1 квартал по НДС мы получили по электронной почте более 300 "Спасибо" от налогоплательщиков :) !

16 апреля 2015 на серверах хостинг провайдера произошел сбой, в связи с чем сайт работал нестабильно. В настоящий момент проблемы устранены.

15 апреля 2015 стал доступен конвертер Уведомления о контролируемых сделках.

14 апреля 2015 стал доступен Конвертер журнала учета счетов-фактур в формате Приказа ФНС России от 04.03.2015 N ММВ-7-6/93@. С его помощью можно из Excel загрузить в Налогоплательщик ЮЛ не просто декларацию по НДС, а сами счет-фактуры. Купить конвертер можно, связавшись с нами.

Читайте также: