Skip to main content

Automate SAP with python!

Project description

Github - https://github.com/kamildemocko/PySapScript

SAP scripting for use in Python.
Can perform different actions in SAP GUI client on Windows.

Documentation

https://kamildemocko.github.io/PySapScript/

pdoc --html --output-dir docs .\src\pysapscript\

Installation

uv sync
uv pip install -e .

Usage

Create pysapscript object

import pysapscript

sapscript = pysapscript.Sapscript()

parameter default_window_title: = "SAP Easy Access"

Launch Sap

sapscript.launch_sap(
    sid="SQ4",
    client="012",
    user="robot_t",
    password=os.getenv("secret_password")
)

additional parameters:

root_sap_dir = Path(r"C:\Program Files (x86)\SAP\FrontEnd\SAPgui")
maximise = True
language = "de"
quit_auto = True

Attach to an already opened window:

from pysapscript.window import Window

window: Window = sapscript.attach_window(0, 0)

positional parameters (0, 0) -> (connection, session)

Quitting SAP:

  • pysapscript will automatically quit if not manually specified in launch_sap parameter
  • manual quitting method: sapscript.quit()

Performing action:

element: use SAP path starting with wnd[0] for element arguments, for example wnd[0]/usr/txtMAX_SEL

  • element paths can be found by recording a sapscript with SAP GUI or by applications like SAP Script Tracker
window = sapscript.attach.window(0, 0)

window.maximize()
window.restore()
window.close()

window.start_transaction(value)
window.navigate(NavigateAction.enter)
window.navigate(NavigateAction.back)

window.write(element, value)
window.press(element)
window.send_v_key(value[, focus_element=True, value=0])
window.select(element)
selected = window.is_selected(element)
window.set_checkbox(value)
window.read(element)
window.visualize(element[, seconds=1])
window.exists(element)

window.set_dropdown(element, "02")
window.set_dropdown(element, "Excel File XLSX", value_type="text")

table: ShellTable = window.read_shell_table(element)
tree: TreeTable = window.read_shell_tree(element)
html_content = window.read_html_viewer(element)

Table actions

ShellTable uses polars, but can also be return pandas or dictionary

ShellTable

from pysapscript.shell_table import ShellTable

table: ShellTable = window.read_shell_table()

# shape
table.rows
table.columns

# getters
table.to_dict()
table.to_dicts()
table.to_polars_dataframe()
table.to_pandas_dataframe()

table.cell(row_value, col_value_or_name)
table.get_column_names()

# actions
table.load()
table.press_button(value)
table.select_rows([0, 1, 2])
table.select_row(1)
table.change_checkbox(element, value)

table.press_context_menu_item("%XXL")
table.press_context_menu_item("Excel File...", item_type="text")

Tree actions

Holds data in a list of Node

ShellTree

tree: ShellTree = window.read_shell_tree()

# slicing
tree[index]
tree[start:stop:step]

# getters
node = tree.get_node_by_key("         7")
node = tree.get_node_by_label("Name 1")
list_of_nodes = tree.get_nodes()
list_of_node_folders = tree.get_node_folders()
list_of_node_not_foldres = tree.get_node_not_folders()

# other
tree.select_all()
tree.unselect_all()

tree.expand_all()
tree.collapse_all()

Node

node = tree.get_node_by_label("Name 1")

children_nodes = node.get_children()

node.select()
node.unselect()
node.expand()
node.collapse()

node.double_click()

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

pysapscript-3.5.0.tar.gz (111.0 kB view details)

Uploaded Source

Built Distribution

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

pysapscript-3.5.0-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file pysapscript-3.5.0.tar.gz.

File metadata

  • Download URL: pysapscript-3.5.0.tar.gz
  • Upload date:
  • Size: 111.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for pysapscript-3.5.0.tar.gz
Algorithm Hash digest
SHA256 810b2f3428b1ac11107fc998021e1abe36f99487f4384cc9772e5d342b916e7c
MD5 3b7aed0c52089456a17be2e75717c5af
BLAKE2b-256 c800720c904232d2e38f311cc6b6997172cd62873df378bfe2d82203345b17d5

See more details on using hashes here.

File details

Details for the file pysapscript-3.5.0-py3-none-any.whl.

File metadata

  • Download URL: pysapscript-3.5.0-py3-none-any.whl
  • Upload date:
  • Size: 26.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.10

File hashes

Hashes for pysapscript-3.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 af8943ac86d867d38c4e350470932afa90fbdcbd7c1ee625a93c09a83c005025
MD5 11ec1fe9be3e187760190191904151f4
BLAKE2b-256 4c2237f4e7a0be72dc12a4d1d92da0b0d0c1b9c6a32e89d2ced83ee3331d0bbb

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