Metadata-Version: 2.4
Name: xaeian
Version: 0.2.0
Summary: Python utilities for files, strings, time, serial, structs, and database
Author: Xaeian
License: MIT
Project-URL: Repository, https://github.com/Xaeian/Python
Keywords: utilities,files,database,serial,crc,struct
Requires-Python: >=3.12
Description-Content-Type: text/markdown
Provides-Extra: db
Requires-Dist: psycopg2-binary; extra == "db"
Requires-Dist: pymysql; extra == "db"
Provides-Extra: db-async
Requires-Dist: aiomysql; extra == "db-async"
Requires-Dist: aiosqlite; extra == "db-async"
Requires-Dist: asyncpg; extra == "db-async"
Provides-Extra: mf
Requires-Dist: Pillow; extra == "mf"
Requires-Dist: PyMuPDF; extra == "mf"
Requires-Dist: pypdf; extra == "mf"
Provides-Extra: pdf
Requires-Dist: Pillow; extra == "pdf"
Requires-Dist: reportlab; extra == "pdf"
Provides-Extra: serial
Requires-Dist: pyserial; extra == "serial"
Provides-Extra: time
Requires-Dist: pytz; extra == "time"
Requires-Dist: tzlocal; extra == "time"
Provides-Extra: all
Requires-Dist: Pillow; extra == "all"
Requires-Dist: PyMuPDF; extra == "all"
Requires-Dist: aiomysql; extra == "all"
Requires-Dist: aiosqlite; extra == "all"
Requires-Dist: asyncpg; extra == "all"
Requires-Dist: psycopg2-binary; extra == "all"
Requires-Dist: pymysql; extra == "all"
Requires-Dist: pypdf; extra == "all"
Requires-Dist: pyserial; extra == "all"
Requires-Dist: pytz; extra == "all"
Requires-Dist: reportlab; extra == "all"
Requires-Dist: tzlocal; extra == "all"

# `xaeian`

Python utilities for files, strings, time, serial, structs, media, PDF, and database.
Zero dependencies for core modules. Optional extras for time, serial, media, PDF, and database backends.

## Install

```bash
pip install xaeian            # core
pip install xaeian[time]      # + pytz, tzlocal
pip install xaeian[serial]    # + pyserial
pip install xaeian[mf]        # + pypdf, PyMuPDF, Pillow
pip install xaeian[pdf]       # + reportlab, svglib, Pillow
pip install xaeian[db]        # + pymysql, psycopg2
pip install xaeian[db-async]  # + aiomysql, asyncpg, aiosqlite
pip install xaeian[all]       # everything
```

## Modules

| Module        | Description                                      | Docs                                                  |
| ------------- | ------------------------------------------------ | ----------------------------------------------------- |
| `files`       | FILE, DIR, PATH, JSON, CSV, INI                  | [xaeian/files.py](xaeian/readme.md#files)             |
| `files_async` | Async wrappers via `asyncio.to_thread()`         | [xaeian/files_async.py](xaeian/readme.md#files_async) |
| `xstring`     | split, replace, strip comments, passwords        | [xaeian/xstring.py](xaeian/readme.md#xstring)         |
| `xtime`       | Datetime parsing, arithmetic, rounding           | [xaeian/xtime.py](xaeian/readme.md#xtime)             |
| `colors`      | ANSI 256-color terminal codes                    | [xaeian/colors.py](xaeian/readme.md#colors)           |
| `log`         | Colored logging with file rotation               | [xaeian/log.py](xaeian/readme.md#log)                 |
| `crc`         | CRC-8/16/32 with predefined variants             | [xaeian/crc.py](xaeian/readme.md#crc)                 |
| `cstruct`     | Binary struct serialization (C-like)             | [xaeian/cstruct.py](xaeian/readme.md#cstruct)         |
| `cmd`         | Shell command helpers                            | [xaeian/cmd.py](xaeian/readme.md#cmd)                 |
| `mf`          | Compress, convert, strip metadata (PDF & images) | [xaeian/mf/](xaeian/mf/readme.md)                     |
| `pdf`         | PDF generation with fluent API                   | [xaeian/pdf/](xaeian/pdf/readme.md)                   |
| `serial_port` | Serial communication with colored output         | [xaeian/serial_port.py](xaeian/readme.md#serial_port) |
| `cbash`       | Embedded device console protocol                 | [xaeian/cbash.py](xaeian/readme.md#cbash)             |
| `db`          | Database abstraction (SQLite, MySQL, PostgreSQL) | [xaeian/db/](xaeian/db/readme.md)                     |

## Quick Start

```python
from xaeian import FILE, JSON, CSV, logger, generate_password
from xaeian.xtime import Time
from xaeian.crc import crc16_modbus

# File operations
config = JSON.load("config")
CSV.save("export", [{"name": "Jan", "score": 95}, {"name": "Anna", "score": 88}])
# Time arithmetic
deadline = Time("2025-03-01") + "2w" # + 2 weeks
if Time() > deadline:
  print("Overdue!")
# CRC protection
frame = crc16_modbus.encode(b"\x01\x03\x00\x00\x00\x0A")
if crc16_modbus.decode(frame):
  print("Valid Modbus frame")
# Colored logging
log = logger("app", file="app.log", color=True)
log.info(f"New password: {generate_password(16)}")
```

**Media files:**

```python
from xaeian.mf.min import compress
from xaeian.mf.meta import scrub_metadata

compress("report.pdf")              # → report-min.pdf
compress("photo.jpg", max_px=1280)  # → photo-min.jpg
scrub_metadata("photo.jpg")         # → photo-nometa.jpg
```

**PDF generation:**

```python
from xaeian.pdf import PDF

with PDF("output.pdf") as pdf:
  pdf.font("Helvetica", 16, "Bold")
  pdf.text("Hello World")
  pdf.enter()
  pdf.font(size=12, mode="Regular")
  pdf.text("Second line of text.")
```

**Database example:**

```python
from xaeian.db import Database

db = Database("sqlite", "app.db")
db.insert("users", {"name": "Jan", "email": "jan@example.com"})
user = db.find_one("users", name="Jan")
users = db.find("users", order="name", limit=10)
with db.transaction():
  db.update("users", {"verified": True}, "id = ?", user["id"])
  db.insert("logs", {"action": "verify", "user_id": user["id"]})
```
