Metadata-Version: 2.1
Name: my_table_db
Version: 20.0.0
Summary: A library for conclusion table db
Author: k0ng999
Author-email: baydar_14@mail.ru
License: MIT
Description-Content-Type: text/markdown
License-File: LICENSE

# Библиотека my_table_db

Это библиотека для вывода в консоль таблицы из базы данных
***


## Использование
### Функции my_table_db , my_table_db_name
Принимает именованные аргументы (rows,name_arg1, name_arg2, ..., name_arg7) и их соответствующие значения (arg1, arg2, ..., arg7). Она форматирует эти входные данные в аккуратную строку с каждой парой имя-значение, разделенной символом |. Функция может обрабатывать различное количество аргументов, от одного до семи пар.

# Параметры

* name_arg1 до name_arg7: Опциональные строки, представляющие имена аргументов.
* arg1 до arg7: Опциональные значения, соответствующие каждому имени.



# Возвращаемое значение
#### my_table_db
```shell
name_colum    | name_colum    | name_colum    | name_colum    | name_colum    | name_colum    | name_colum
----------------------------------------------------------------------------------------------------------
arg           | arg           | arg           | arg           | arg           | arg           | arg       
arg           | arg           | arg           | arg           | arg           | arg           | arg       
arg           | arg           | arg           | arg           | arg           | arg           | arg   
arg           | arg           | arg           | arg           | arg           | arg           | arg   
arg           | arg           | arg           | arg           | arg           | arg           | arg   
arg           | arg           | arg           | arg           | arg           | arg           | arg   
```
#### my_table_db_name
```shell
name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg
name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg
name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg
name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg
name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg
name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg    | name_colum:    arg

```

***
### Функция `my_table_db_full()`, `my_table_db_full_name()`
Принимает именованные аргументы (rows, colum_name). Она выводит всю таблицу в консоль с использованием оригинальных названий столбцов.

#### my_table_db_full

```shell
original_name_colum    | original_name_colum    | original_name_colum    | original_name_colum    | original_name_colum    | original_name_colum    | original_name_colum
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------
arg                    | arg                    | arg                    | arg                    | arg                    | arg                    | arg                
arg                    | arg                    | arg                    | arg                    | arg                    | arg                    | arg                
arg                    | arg                    | arg                    | arg                    | arg                    | arg                    | arg                
arg                    | arg                    | arg                    | arg                    | arg                    | arg                    | arg                
arg                    | arg                    | arg                    | arg                    | arg                    | arg                    | arg                
arg                    | arg                    | arg                    | arg                    | arg                    | arg                    | arg                

```

#### my_table_db_full_name

```shell
original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg
original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg
original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg
original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg
original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg
original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg    | original_name_colum:    arg

```

***

# Установка

` pip install my_table_db `

## Пример 1

Содержимое таблицы
```csv
id  Name    Salary
1   Alice   50000
2   Bob     60000
```
Код с использованием my_table_db_full_name

```python
import psycopg2
from my_table_db import my_table_db_full_name

def fetch_data():
    conn = None
    try:
        conn = con = psycopg2.connect(
            dbname=...,
            user=...,
            password=...,
            host=...,
            port=...)
        cur = conn.cursor()
        cur.execute("SELECT * FROM employees")
        
        rows = cur.fetchall()   #Получаем все строки
        colum_name = [desc[0] for desc in cur.description]  #Получаем все названия колонок
        
        my_table_db_full_name(rows, colum_name)  #Выводим на экран всю табличку
        
        cur.close()
    except (Exception, psycopg2.DatabaseError) as error:
        print(error)
    finally:
        if conn is not None:
            conn.close()
            print()
            print("Database connection closed.")


fetch_data()
```

#### Вывод

```shell
id:    1    | Name:    Alice    | Salary:    50000
id:    2    | Name:    Bob      | Salary:    60000

Database connection closed.
```

## Пример 2
Код с использованием my_table_db_name

```python
import psycopg2
from my_table_db import my_table_db_name

def fetch_data():
    conn = None
    try:
        conn = con = psycopg2.connect(
            dbname=...,
            user=...,
            password=...,
            host=...,
            port=...)
        cur = conn.cursor()
        cur.execute("SELECT * FROM employees")
        
        rows = cur.fetchall()   #Получаем все строки
        for row in rows:
            my_table_db_name(rows,'id',row[0],'Name',row[1],'Salary',row[2])  #Выводим на экран табличку 
        
        cur.close()
    except (Exception, psycopg2.DatabaseError) as error:
        print(error)
    finally:
        if conn is not None:
            conn.close()
            print()
            print("Database connection closed.")


fetch_data()
```
```shell
id:    1    | Name:    Alice    | Salary:    50000
id:    2    | Name:    Bob      | Salary:    60000

Database connection closed.
```
### Различия между 1 и 2 способом в том что мы можем вывести не всю табличку, а только то что хотим, а так же мы можем указать собственное имя столбца. Например мы могли написать 
```python
my_table_db_name(rows,'Имя',row[1],'Зарплата',row[2])
```
И в этом случае вывелось бы:

```shell
Имя:    Alice    | Зарплата:    50000
Имя:    Bob      | Зарплата:    60000
```
## Пример 3

#### Если вы хотите что бы вывод был вот такой

```shell
id    | Имя      | Зарплата
---------------------------
1     | Alice    | 50000   
2     | Bob      | 60000  
```

#### То используйте либо `my_table_db_full()` либо `my_table_db_full_name()`

### my_table_db_full

```python
my_table_db_full(rows, colum_name)
```
```shell
id    | Name      | Salary
---------------------------
1     | Alice    | 50000   
2     | Bob      | 60000  
```

### my_table_db

```python
my_table_db(rows,'Имя',row[1],'Зарплата',row[2])
```
```shell
Имя      | Зарплата
-------------------
Alice    | 50000   
Bob      | 60000  
```

***

# Заключение
#### Библиотека my_table_db полезна для форматирования и отображения наборов пар имя-значение в структурированном и читаемом формате. Она может обрабатывать различное количество аргументов и гарантирует, что вывод останется выровненным и легко читаемым.

***
### Автор

Автор: k0ng999
