Menu

Tree [bf8cf8] main /
 History

HTTPS access


File Date Author Commit
 .githooks 2022-07-30 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [144699] Develop (#94)
 .idea 2023-03-27 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [ad552f] Develop (#343)
 .vscode 2023-05-03 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [bf8cf8] Develop (#376)
 cmds 2022-12-03 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [1a9c53] Develop (#209)
 docs 2023-05-03 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [bf8cf8] Develop (#376)
 ooodev 2023-05-03 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [bf8cf8] Develop (#376)
 src 2023-04-02 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [5e9e07] Develop (#347)
 tests 2023-05-03 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [bf8cf8] Develop (#376)
 .gitignore 2022-05-11 Paul Moss Paul Moss [c8e746] first commit
 LICENSE 2022-06-08 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [38a039] Develop (#36)
 README.rst 2023-04-07 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [c6704b] Develop (#351)
 conftest.py 2022-07-15 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [52237b] Develop (#66)
 main.py 2023-03-27 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [ad552f] Develop (#343)
 poetry.lock 2023-04-22 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [ac0c29] Develop (#356)
 pyproject.toml 2023-05-02 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [ec5c3a] Develop (#370)
 setup.py 2022-10-28 Barry-Thomas-Paul: Moss Barry-Thomas-Paul: Moss [71c09e] Develop (#153)

Read Me

OOO Development Tools

License Apache PyPI - Python Version PyPI - Wheel Github

OOO Development Tools (OooDev) is intended for programmers who want to learn and use the Python version of the LibreOffice API.

This allows Python to control and manipulate LibreOffice's text, drawing, presentation, spreadsheet, and database applications, and a lot more (e.g. its spell checker, forms designer, and charting tools).

One of the aims is to develop utility code to help flatten the steep learning curve for the API. For example, The Lo class simplifies the steps needed to initialize the API (by creating a connection to a LibreOffice process), to open/create a document, save it, and close down LibreOffice.

Currently this project has been tested on LibreOffice in Windows and Linux (Ubuntu).

Advantages of Python

Macros are pieces of programming code that runs in office suites and helps automate routine tasks. Specifically, in LibreOffice API these codes can be written with so many programming languages thanks to the Universal Network Objects (UNO).

Since LibreOffice is multi-platform we can use our documents at different platforms like Mac, Windows, and Linux. So we need a cross-platform language to run our macros at different platforms.

Python has the advantage that it is cross-platform and can run inside the office environment as macros and outside office environment on the command line.

Python has a vast set libraries that can be used in a project, including Numpy and Numexpr which are excellent and powerful at numeric computation.

This makes Python and excellent choice with maximum flexibility.

Documentation

Read documentation

Installation

PIP

ooo-dev-tools PyPI

$ pip install ooo-dev-tools

Modules

Currently there are more than 4,000 classes in this framework.

Include modules:
  • Calc (Calc)
  • Write (Write)
  • Draw (LibreOffice Draw/Impress)
  • Forms (Support for building forms)
  • Dialogs (Build dialog forms)
  • GUI (Various GUI methods for manipulating LO Windows)
  • Lo (Various methods common to LO applications)
  • FileIO (File Input and Output for working with LO)
  • Format (Format Module — hundreds of classes — for Styling and modifying the many Documents and Sheets properties.)
  • Props (Various methods setting and getting the many properties of Office objects)
  • Info (Various method for getting information about LO applications)
  • Color (Various color utils)
  • DateUtil (Date Time utilities)
  • ImagesLo (Various methods for working with Images)
  • Props (Various methods for working with the many API properties)
  • Chart2 (charting)
  • Chart (charting)
  • Gallery (Methods for accessing and reporting on the Gallery)
  • Theme (Access to LibreOffice Theme Properties)
  • Units (Various unit methods and classes for passing different kinds of units in LibreOffice such as inches, millimeters, points, pixels.)
  • And more ...
Future releases will add:
  • Base (LibreOffice Base)
  • Clip (clipboard support)
  • Mail (Mail service provider)
  • Print (Print service provider)
  • And more ...

Inspiration

Much of this project is inspired by the work of Dr. Andrew Davison and the work on Java LibreOffice Programming

See LibreOffice Programming that aims to gradually explain this content in a python context.

Other

Figure 1: Calc Find and Replace Automation Example

Calc Find and Replace Automation
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.