A Python library for interacting with 1C:Enterprise databases via COM connection.
Project description
1C Interaction Library (oneCInteraction)
A modular Python library for interacting with «1C:Enterprise» databases via a COM connection (V83.COMConnector). It enables seamless integration of 1C with websites, Telegram bots, or other external services.
Features
- Full COM Connection Support via
win32com. - Nomenclature and Categories Management: retrieve group trees, batch load products, prices, and stock balances across warehouses.
- Product Characteristics: read variant properties from information registers or parse text descriptions.
- Images: download product images directly from the 1C database to the local disk.
- Order Management: create customer orders, track statuses, and update document comments with customer contact details.
- Smart Logging: automatically creates log files in the directory of the host project importing the library.
Installation
This library requires a Windows operating system with the 1C:Enterprise 8.3 platform installed and the pywin32 package.
Install the package in local editable mode:
pip install -e .
Architecture Overview
The library is built on the principle of composition: the main Connection class initializes the COM connection and hosts specialized managers:
Connection.nomenclature(NomenclatureManager) — manages products and images.Connection.groups(GroupsManager) — manages category hierarchy.Connection.characteristics(CharacteristicsManager) — reads properties of product variants.Connection.orders(OrdersManager) — handles creation and updates of customer orders.
Detailed Class and Function Reference
1. Main Class Connection
The Connection class (located in connection.py) manages the COM connection to 1C and holds general settings.
Constructor:
def __init__(self, s_oneCDatabasePathIn: str, s_usernameIn: str, s_passwordIn: str)
s_oneCDatabasePathIn(str): Absolute path to the file-based 1C database on disk.s_usernameIn(str): 1C username.s_passwordIn(str): 1C password.
Key Attributes:
s_warehouse_code(str): 1C warehouse code for new orders.s_counteragent_code(str): 1C counteragent (customer) code for new orders.s_organisation_code(str): 1C organization code for new orders.sl_price_types(list): List of price type names to cache automatically (defaults to["Розничная", "Оптовая"]).c_v8: The active 1C COM connection object (equalsNoneif not connected).
Methods:
initiate_connection() -> None: Establishes the COM connection to 1C usingV83.COMConnectorand caches price type references.close_connection() -> None: Closes the connection and releases COM resources.get_price_type_ref(s_nameIn: str): Returns the 1C COM reference for a price type by its name.
2. Data Structures (structures.py)
All data models are defined in structures.py.
Nomenclature
Represents a product.
s_name(str): Product name.s_article(str): Product article (SKU).s_description(str): Product description.l_variety(list ofVariety): List of available variants/characteristics of the product.s_unit(str): Unit of measurement (defaults to"шт.").s_parent_uuid(str): UUID of the parent group/category.s_uuid(str): Unique identifier (UUID) of the product in 1C.s_code(str): 1C product code.l_images(list): List of image UUIDs associated with the product in 1C.
Variety
Represents a product variant with specific prices and stock levels.
n_price(float): Retail price for the variant.n_priceOpt(float): Wholesale price for the variant.d_count(dict): Stock balances by warehouse in the format{"Warehouse Name": quantity}.l_characteristics(list ofCharacteristic): List of characteristics for the variant.
Characteristic
A key-value pair for a variant property.
s_name(str): Property name (e.g.,"Color").s_value(str): Property value (e.g.,"Red").
Group
A product group (category).
s_name(str): Group name.l_subGroups(list ofGroup): List of subgroups.l_nomenclatures(list ofNomenclature): List of products inside the group.c_ref: COM reference to the group in 1C.s_code(str): 1C group code.s_uuid(str): UUID of the group in 1C.
Customer
Information about the buyer.
s_customerTelegramId(str): Telegram ID of the user.s_customerPIB(str): Full name (PIB) of the customer.s_customerPhone(str): Customer's phone number.s_customerAddress(str): Delivery address of the customer.
OrderItem
An item in the order.
s_productArticle(str): Product article (SKU).s_productPropertie(str): Selected characteristic name (if any).n_productCount(int): Quantity of items.
Order
A buyer's order.
c_orderCustomer(Customer): Customer details object.l_orderItemsList(list ofOrderItem): List of ordered items.s_TTN(str): Waybill number (TTN).s_status(str): Status of the order in 1C.s_date(str): Order creation date (automatically generated).n_orderCode(str / int): Order number in 1C.
Calling str(order_obj) returns a nicely formatted HTML string suitable for sending to a Telegram bot.
3. Nomenclature Manager NomenclatureManager (Connection.nomenclature)
Defined in nomenclature.py.
get(s_articleIn: str = "", s_nameIn: str = "", s_codeIn: str = "") -> Nomenclature | NoneSearches for and returns a product by its article, name, or code. Fetches retail/wholesale prices, stock balances by warehouses, and characteristics.get_images(c_productObjIn: Nomenclature, s_imageDirIn: str = None) -> listDownloads all attached images for a product from 1C. Saves them in the specified directorys_imageDirIn(defaults todata/images). Returns a list of the saved filenames (e.g.,["[uuid]_0.jpg"]).get_by_group(c_groupRefIn) -> listBatch fetches all products within a specific 1C group. Using optimized COM queries, this method minimizes DB requests and operates significantly faster than callingget()sequentially in a loop.
4. Category Manager GroupsManager (Connection.groups)
Defined in groups.py.
get_tree(sl_ignoredCategoriesNamesIn: list) -> listBuilds the hierarchical category tree from 1C. Branches whose names are listed insl_ignoredCategoriesNamesInare excluded along with all their subcategories.get_by_name(s_nameIn: str) -> Group | NoneFinds a reference to a group by its exact name in 1C.get_full_path(c_groupRefIn) -> strBuilds the full text hierarchy path to a category, traversing up to the root parent (e.g.,"Clothing > Men's > Shoes").
5. Characteristics Manager CharacteristicsManager (Connection.characteristics)
Defined in characteristics.py.
parse_name(s_charNameIn: str) -> list(static method) Parses a characteristic name string (e.g.,"Size: L"or"Color - Red") and returns a list ofCharacteristicobjects.get(c_charRefIn, s_charNameIn: str = "") -> listQueries characteristic properties from theЗначенияСвойствОбъектовregister. If no properties are found, falls back to parsing the name string viaparse_name().fetch_batch(l_charRefsIn: list) -> dictBatch fetches property values for a list of characteristic references.
6. Orders Manager OrdersManager (Connection.orders)
Defined in orders.py.
push(c_orderObjIn: Order) -> strCreates a new"Заказ покупателя"(Buyer's Order) document in 1C.- Automatically queries the warehouse, counteragent, and organization based on codes specified in the
Connectionobject. - Sets the retail price type, document currency (Hryvnia, code
"980"), and organization's primary bank account. - Adds products from the order, queries the exact price for the specific characteristic selected, and computes totals.
- Attempts to post the document (
Posting). If posting fails, it writes the document in draft/save mode (Write). - Returns the number of the created document in 1C (or an empty string on error).
- Automatically queries the warehouse, counteragent, and organization based on codes specified in the
get(s_codeIn: str) -> Order | NoneRetrieves a buyer's order by its 1C document number and parses it into anOrderobject. The comment field is parsed to retrieve the Telegram ID.get_today() -> listReturns a list of all today's orders created for the configured bot counteragent (filtered by current date and counteragent code).update_info(c_orderObjIn: Order) -> boolUpdates the comment field of the order in 1C. Writes a formatted string to the comment field:"[Full Name] [Phone] [Telegram ID] [Waybill/TTN] [Status]"
7. Logging (log.py)
Defined in log.py.
All actions are logged automatically. The library resolves the root directory of the project that imported it and stores log files in the relative path log/system/[calling_module_name].log.
log_sys(message, errorFlag = 0)— The main logging utility. IferrorFlag=1, prepends an[ERROR]tag.
Usage Example
Complete Workflow (Fetching Products and Creating an Order)
from oneCInteraction import Connection, Customer, Order, OrderItem
# 1. Initialize Connection
c_conn = Connection(
s_oneCDatabasePathIn="C:\\1C_Bases\\ShopDB",
s_usernameIn="AdminBot",
s_passwordIn="secure_password"
)
# 2. Configure 1C Default Codes
c_conn.s_warehouse_code = "000000001" # Warehouse code
c_conn.s_counteragent_code = "000000045" # Bot customer/counteragent code
c_conn.s_organisation_code = "000000001" # Organization code
# 3. Establish connection to 1C
c_conn.initiate_connection()
if c_conn.c_v8:
try:
# 4. Fetch Category Tree
ignored_cats = ["Archive", "System"]
categories = c_conn.groups.get_tree(ignored_cats)
print(f"Loaded {len(categories)} root categories.")
# 5. Get products from the first category
first_group = categories[0]
products = c_conn.nomenclature.get_by_group(first_group.c_ref)
print(f"Found products in group {first_group.s_name}: {len(products)}")
for p in products[:3]:
print(f"Product: {p.s_name} | SKU: {p.s_article}")
if p.l_variety:
v = p.l_variety[0]
print(f" Price: {v.n_price} UAH | Stocks: {v.d_count}")
# Download product images
images = c_conn.nomenclature.get_images(p, s_imageDirIn="static/images")
print(f" Downloaded images: {images}")
# 6. Create a New Order
customer = Customer(
s_customerTelegramIdIn="123456789",
s_customerPIBIn="John Doe",
s_customerPhoneIn="+380991112233",
s_customerAddressIn="Kyiv, Nova Poshta Warehouse #1"
)
items = [
OrderItem(
s_productArticleIn="ART-1024",
s_productPropertieIn="Size: L, Color: Blue",
n_productCountIn=2
)
]
new_order = Order(
c_orderCustomerIn=customer,
l_orderItemsListIn=items
)
# Submit the order to 1C
order_number = c_conn.orders.push(new_order)
if order_number:
print(f"Order created successfully in 1C! Order Number: {order_number}")
# Update TTN and status details
new_order.n_orderCode = order_number
new_order.s_TTN = "20450011223344"
new_order.s_status = "Shipped"
c_conn.orders.update_info(new_order)
# Output order details formatted as HTML string
print(str(new_order))
finally:
# Always clean up and close the connection
c_conn.close_connection()
else:
print("Failed to connect to 1C database.")
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file onecinteraction-1.0.5.tar.gz.
File metadata
- Download URL: onecinteraction-1.0.5.tar.gz
- Upload date:
- Size: 24.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5b150c1ca9f42c1d053db51508b8b6c056698b793a4583b9da26b2868bd128a0
|
|
| MD5 |
0771fbd9e6b7311d32bf21c33729b8ad
|
|
| BLAKE2b-256 |
ca36edc128c1699f35756f6dcbabc3f35a5ceafa7f5dfe160357dad35508b361
|
Provenance
The following attestation bundles were made for onecinteraction-1.0.5.tar.gz:
Publisher:
publish.yml on agcl-x/oneCInteractionLib
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
onecinteraction-1.0.5.tar.gz -
Subject digest:
5b150c1ca9f42c1d053db51508b8b6c056698b793a4583b9da26b2868bd128a0 - Sigstore transparency entry: 1926283930
- Sigstore integration time:
-
Permalink:
agcl-x/oneCInteractionLib@9258cb3b46961d4bc1ceefa6ffd93853ce380238 -
Branch / Tag:
refs/tags/v1.0.5 - Owner: https://github.com/agcl-x
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@9258cb3b46961d4bc1ceefa6ffd93853ce380238 -
Trigger Event:
release
-
Statement type:
File details
Details for the file onecinteraction-1.0.5-py3-none-any.whl.
File metadata
- Download URL: onecinteraction-1.0.5-py3-none-any.whl
- Upload date:
- Size: 23.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
91164296d1617bfffae59d44ab9cb2a0a218ffab148a3acd0cd52de363991fa5
|
|
| MD5 |
4ba61dd3d14e0950b594ff3bafad72b9
|
|
| BLAKE2b-256 |
4dcfadc4a7d0a0b8e721f602985f70296e2e796d35fd4963ff1c4bc66dea3c5e
|
Provenance
The following attestation bundles were made for onecinteraction-1.0.5-py3-none-any.whl:
Publisher:
publish.yml on agcl-x/oneCInteractionLib
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
onecinteraction-1.0.5-py3-none-any.whl -
Subject digest:
91164296d1617bfffae59d44ab9cb2a0a218ffab148a3acd0cd52de363991fa5 - Sigstore transparency entry: 1926284362
- Sigstore integration time:
-
Permalink:
agcl-x/oneCInteractionLib@9258cb3b46961d4bc1ceefa6ffd93853ce380238 -
Branch / Tag:
refs/tags/v1.0.5 - Owner: https://github.com/agcl-x
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@9258cb3b46961d4bc1ceefa6ffd93853ce380238 -
Trigger Event:
release
-
Statement type: