Skip to main content

Mechanical scripting API stubs for PyMechanical.

Project description

PyAnsys Python PyPI PyPI Downloads GH-CI Codecov MIT Black pre-commit.ci

Overview

PyMechanical Stubs generates __init__.py files from assembly files in the Mechanical application to create python files that can be used for autocomplete with PyMechanical. Stubs are generated for each version of Mechanical, starting with 2024 R1.

clr-stubs generate Python stubs for .NET assemblies using pythonnet. These stubs are intended to be used by the autocomplete engine of editors like Atom, Sublime, and VS Code, as well as for python documentation generation (for example, with Sphinx)

Why clr-stubs?

If you are writing python code using .NET modules via pythonnet’s clr.AddReference, your IDE’s autocomplete (which usually runs python) will not be able to follow any .NET namespaces or libraries.

The workaround in clr-stubs is to create ‘stubs’ or ‘fakes’ with the same namespaces, types, and metadata that would typically be available in a pure python library. The ‘stubs’ can then be used by your IDE’s autocomplete.

Manually create __init__.py files

  1. Install Mechanical 2024 R1 or R2.

    Note

    Ensure the environment variable, AWP_ROOTDV_DEV, is set to the location of Mechanical 2024 R1 or R2 (C:\Program Files\Ansys Inc\v242).

  2. Clone the repository.

    git clone https://github.com/ansys/pymechanical-stubs.git
  3. Run stub_generator/create_files.py to generate the stubs from Mechanical 2024 R1 or R2.

    python stub_generator/create_files.py

    Note

    There may be an Unhandled Exception when the stubs are done running. If the message, “Done creating all Mechanical stubs” appears, proceed to the next step.

  4. Next, create and activate a virtual environment:

    python -m venv .venv

    Windows:

    .venv\Scripts\activate.bat

    Linux:

    source .venv/bin/activate
  5. Install ansys-mechanical-stubs

    pip install -e .
  6. Make the Sphinx documentation

    make -C doc html

    Note

    You can ignore any current warning messages. It is a lengthy process to generate the documentation.

Installation

You can use pip to install PyMechanical Stubs.

pip install ansys-mechanical-stubs

To install the latest development version, run these commands:

git clone https://github.com/ansys/pymechanical-stubs
cd pymechanical-stubs
pip install -e .

Install in offline mode

If you lack an internet connection or you do not have access to the private Ansys PyPI packages repository, you should install PyMechanical Stubs by downloading the wheelhouse archive for your corresponding machine architecture from the repository’s Releases page.

Each wheelhouse archive contains all of the Python wheels necessary to install PyMechanical Stubs from scratch on Windows, Linux, and MacOS from Python 3.10 to 3.12. In addition, you can install the wheelhouse on a new virtual environment that does not include any previously installed dependencies.

For example, on Linux with Python 3.10, unzip the wheelhouse archive and install it with these commands:

unzip ansys-mechanical-stubs-v0.1.9-wheelhouse-ubuntu-latest-3.10 -d wheelhouse
pip install ansys-mechanical-stubs -f wheelhouse --no-index --upgrade --ignore-installed

If you are on Windows with Python 3.10, unzip the wheelhouse archive to a wheelhouse directory and then install using the same pip install command as in the preceding example.

Note

If desired, you can install the wheelhouse on an isolated or virtual system. See Creation of virtual environments in the Python documentation for the required steps.

Basic usage

This code shows how to import PyMechanical Stubs and its basic capabilities:

from typing import TYPE_CHECKING
import ansys.mechanical.core as mech

if TYPE_CHECKING:
    import ansys.mechanical.stubs.v241.Ansys as Ansys

geometry_import_group = app.Model.GeometryImportGroup
geometry_import = geometry_import_group.AddGeometryImport()

# Lines that start with "Ansys." will autocomplete as you type
geometry_import_format = (
    Ansys.Mechanical.DataModel.Enums.GeometryImportPreference.Format.Automatic
)
geometry_import_preferences = Ansys.ACT.Mechanical.Utilities.GeometryImportPreferences()

Alternatively, you can enable autocomplete in VS Code’s settings.json file with the following steps:

  1. Run pip install ansys-mechanical-core.

  2. Run ansys-mechanical-ideconfig in the terminal to retrieve the information for VS Code’s settings.json file:

    ansys-mechanical-ideconfig --ide vscode --target user --revision 242

    The command returns the path to the settings.json file. Open the file and add the lines from the command output.

  3. Once the settings.json file is updated, you only need to import Ansys to enable autocomplete:

    from typing import TYPE_CHECKING
    import ansys.mechanical.core as mech
    
    if TYPE_CHECKING:
        import Ansys
        from Ansys.Mechanical.DataModel.Enums import *
    
    geometry_import_group = app.Model.GeometryImportGroup
    geometry_import = geometry_import_group.AddGeometryImport()
    
    # Lines that start with "Ansys." will autocomplete as you type
    geometry_import_format = (
        Ansys.Mechanical.DataModel.Enums.GeometryImportPreference.Format.Automatic
    )
    geometry_import_preferences = Ansys.ACT.Mechanical.Utilities.GeometryImportPreferences()

Documentation and issues

Documentation for the latest stable release of PyMechanical Stubs is hosted at PyMechanical Stubs documentation.

In the upper right corner of the documentation’s title bar, there is an option for switching from viewing the documentation for the latest stable release to viewing the documentation for the development version or previously released versions.

On the PyMechanical Stubs Issues page, you can create issues to report bugs and request new features. On the PyMechanical Stubs Discussions page or the Discussions page on the Ansys Developer portal, you can post questions, share ideas, and get community feedback.

To reach the project support team, email pyansys.core@ansys.com.

Credits

This project is inspired by [ironpython-stubs](https://github.com/gtalarico/ironpython-stubs) but is developed from scratch.

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

ansys_mechanical_stubs-0.1.10.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

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

ansys_mechanical_stubs-0.1.10-py3-none-any.whl (1.6 MB view details)

Uploaded Python 3

File details

Details for the file ansys_mechanical_stubs-0.1.10.tar.gz.

File metadata

  • Download URL: ansys_mechanical_stubs-0.1.10.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ansys_mechanical_stubs-0.1.10.tar.gz
Algorithm Hash digest
SHA256 e16f4644a9c63a6700c2c8c612eb2c468f2bb2ac4159f1cc8060ac2dc8522486
MD5 8dda1a9facce70544d1bcc4f0ba0783a
BLAKE2b-256 095d00e661a5b502898c6dacbc0a8383454c0ba404ad347fb558a2a49940203f

See more details on using hashes here.

Provenance

The following attestation bundles were made for ansys_mechanical_stubs-0.1.10.tar.gz:

Publisher: ci_cd.yml on ansys/pymechanical-stubs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ansys_mechanical_stubs-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for ansys_mechanical_stubs-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 bf35b22d2a19e5964ae9c0f424fad42fe1b9406a2fd6d8e4eeaa52ea38ff5536
MD5 911bf827f6b42c576c0bf0a42a5dbb42
BLAKE2b-256 2d7eecb18fa9c98cd39643dbcfedfce95391520fe480c0ea7cc76f4cb79d77d1

See more details on using hashes here.

Provenance

The following attestation bundles were made for ansys_mechanical_stubs-0.1.10-py3-none-any.whl:

Publisher: ci_cd.yml on ansys/pymechanical-stubs

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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