Skip to main content

Pure Python COM package

Project description

comtypes

Works on Windows only
PyPI version PyPI - Python Version PyPI - Python Requires
PyPI - License PyPI - Downloads
GitHub Repo stars GitHub forks Ruff
Tidelift Subscription Coverage

comtypes is a lightweight pure Python COM package based on the ctypes foreign function interface library.

comtypes allows you to define, call, and implement custom and dispatch-based COM interfaces in pure Python.

comtypes requires Windows and Python 3.9 or later.

  • Note about Python 3.15 and enum behavior
    Starting with Python 3.15, the internal handling of IntFlag(Flag) values is planned to change:
    Negative IntFlag members will be reinterpreted by masking them to the defined positive bit domain, instead of keeping their original negative literal values.
    This can affect enumeration types generated by comtypes from COM type libraries. Action is needed to maintain literal evaluation.
    For details and ongoing discussion, see: GH-894.
  • Version 1.4.12 is the last version to support Python 3.8.
  • Version <= 1.4.7 does not work with Python 3.13 as reported in GH-618. Version 1.4.8 can work with Python 3.13.
  • Version 1.4.6 is the last version to support Python 3.7.
  • Version 1.2.1 is the last version to support Python 2.7 and 3.3–3.6.
  • Certain comtypes functions may not work correctly in Python 3.8 and 3.9 as reported in GH-212. This bug has been fixed in Python >= 3.10.10 and >= 3.11.2.

Installation

comtypes is available on PyPI and can be installed with pip:

# PyPI
pip install comtypes

The source code is currently hosted here on GitHub.

Dependencies

comtypes is a pure Python package — it has no additional required dependencies.

Optional functionalities can be enabled by installing:

  • numpy, in order to process arrays as numpy's ndarray.
  • mypy or other static type checkers, in order to interpret type hints.

None of these packages, however, are required in order to run comtypes.

Community

The GitHub repository is used for tracking issues, reporting bugs, and contributing to the codebase and documentation.

For Enterprise

Available as part of the Tidelift Subscription.

This project and the maintainers of thousands of other packages are working with Tidelift to deliver one enterprise subscription that covers all of the open source you use.

Learn more.

Frequently Asked Questions

Q: Why does this package not support platforms other than Windows?

A: The Microsoft Component Object Model (COM) is a technology that is unique to Windows and is not supported on other platforms.

The phrase "COM is a platform-independent" in the MS documentation means that COM maintains compatibility across different versions of Windows, and does NOT imply that it is supported on Linux or Mac.

For as long as COM is not supported outside of Windows, there is no plan to port comtypes to other platforms.

Q: Why does cannot import name 'COMError' from '_ctypes' error occur when using this package on platforms other than Windows?

A: The _ctypes is part of the internal implementation of the ctypes standard library that exists for Python on all platforms. However, COMError and COM-related features are only implemented in Python for Windows.

In cross-platform software development, care must be taken to ensure that codebases that depend on comtypes do not execute in environments other than Windows.

Q: Despite a script that depends on comtypes having run successfully before, a error (ImportError, NameError, or SyntaxError) is raised now, and the same error occurs again and again.

A: Executing py -m comtypes.clear_cache and then running the script again might resolve the problem.

When comtypes.client.GetModule is called (either directly or indirectly), comtypes generates Python module files.
If Python is forced to terminate or crashes in the middle of file generation, the codebase written to the file becomes partial.
When Python tries to import this unexecutable partial codebase module, an error occurs.

Executing py -m comtypes.clear_cache identifies the directories where the "cache module files" are stored and deletes them.
After deleting these partial modules and running the script again, comtypes.client.GetModule is called and executable modules are generated anew.

However, if the script implementation does not use comtypes.client.GetModule or processes generated files, it may not be a solution.

Documentation

The documentation is currently hosted here on ReadTheDocs.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

comtypes-1.4.15.tar.gz (241.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

comtypes-1.4.15-py3-none-any.whl (274.6 kB view details)

Uploaded Python 3

File details

Details for the file comtypes-1.4.15.tar.gz.

File metadata

  • Download URL: comtypes-1.4.15.tar.gz
  • Upload date:
  • Size: 241.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for comtypes-1.4.15.tar.gz
Algorithm Hash digest
SHA256 c72b9968a4e920087183a364c5a13b174e02b11c302cdd92690d14c95ac1b312
MD5 53a39091fcbc5abcc2d5d69b570fd6af
BLAKE2b-256 08a22db93b226887c9a9a354cb39269507213e171fca5be32aeef21b47f14aeb

See more details on using hashes here.

File details

Details for the file comtypes-1.4.15-py3-none-any.whl.

File metadata

  • Download URL: comtypes-1.4.15-py3-none-any.whl
  • Upload date:
  • Size: 274.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for comtypes-1.4.15-py3-none-any.whl
Algorithm Hash digest
SHA256 cda90486de8762ec57d7ce04e68721920911f3f03415cb29afdf7609c427c7e3
MD5 3961c1677562ea4fad78be85b6e9e2bf
BLAKE2b-256 032fca9029d5da14b5a3a103d6061149a4a94a54ab848f56c7d2809dbb36f48c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page