Getting started with PyCaosDB



PyCaosDB needs at least Python 3.6. Additionally, the following packages are required (they will typically be installed automatically):

  • lxml
  • PyYaml
  • PySocks

How to install


Make sure that Python (at least version 3.6) and pip is installed, using your system tools and documentation.

Then open a terminal and continue in the Generic installation section.


If a Python distribution is not yet installed, we recommend Anaconda Python, which you can download for free from The “Anaconda Individual Edition” provides most of all packages you will ever need out of the box. If you prefer, you may also install the leaner “Miniconda” installer, which allows you to install packages as you need them.

After installation, open an Anaconda prompt from the Windows menu and continue in the Generic installation section.


If there is no Python 3 installed yet, there are two main ways to obtain it: Either get the binary package from or, for advanced users, install via Homebrew. After installation from, it is recommended to also update the TLS certificates for Python (this requires administrator rights for your user):

# Replace this with your Python version number:
cd /Applications/Python\ 3.9/

# This needs administrator rights:
sudo ./Install\ Certificates.command

After these steps, you may continue with the Generic installation.

Generic installation

To install PyCaosDB locally, use pip3 (also called pip on some systems):

pip3 install --user caosdb

Alternatively, obtain the sources from GitLab and install from there (git must be installed for this option):

git clone
cd caosdb-pylib
pip3 install --user .


The configuration is done using ini configuration files. PyCaosDB tries to read from the inifile specified in the environment variable PYCAOSDBINI or alternatively in ~/.pycaosdb.ini upon import. After that, the ini file pycaosdb.ini in the current working directory will be read additionally, if it exists.

Here, we will look at the most common configuration options. For a full and comprehensive description please check out pycaosdb.ini file You can download this file and use it as a starting point.

Typically, you need to change at least the url and username fields as required. (Ask your CaosDB administrator or IT crowd if you do not know what to put there, but for the demo instances, username=admin and password=caosdb should work).


The default configuration (that your are asked for your password when ever a connection is created can be changed by setting password_method:

  • with password_method=input password (and possibly user) will be queried on demand (default)
  • use the password manager pass by using pass as value, see also the ArchWiki entry. This also requires password_identifier which refers to the identifier within pass for the desired password.
  • install the python package keyring, to use the system keyring/wallet (macOS, GNOME, KDE, Windows). The password will be queried on first usage.
  • with password_method=plain (strongly discouraged)

The following illustrates the recommended options:

# using "pass" password manager

# using the system keyring/wallet (macOS, GNOME, KDE, Windows)

SSL Certificate

In some cases (especially if you are testing CaosDB) you might need to supply an SSL certificate to allow SSL encryption.


Further Settings

As mentioned above, a complete list of options can be found in the pycaosdb.ini file in the examples folder of the source code.

Try it out

Start Python and check whether the you can access the database. (You will be asked for the password):

In [1]: import caosdb as db
In [2]: db.Info()
Please enter the password:  # It's `caosdb` for the demo server.
Out[2]: Connection to CaosDB with 501 Records.

Note: This setup will ask you for your password whenever a new connection is created. If you do not like this, check out the “Authentication” section in the configuration documentation.

Now would be a good time to continue with the tutorials.

Run Unit Tests


Code Formatting

autopep8 -i -r ./


Build documentation in build/ with make doc.


  • sphinx
  • sphinx-autoapi
  • recommonmark