Skip to main content

A utilities module that contains classes and functions that simplify interfaces with files and databases.

Project description

Describe project here

https://img.shields.io/badge/code%20style-black-000000.svg https://img.shields.io/badge/%20imports-isort-%231674b1?style=flat&labelColor=ef8336 Documentation Status http://www.mypy-lang.org/static/mypy_badge.svg

Overview

This library contains basic utility classes and functions that enable faster Python programming. THese functions and methods standardize the process for reading in files of different types to include .csv, .txt, .xls, .xlsx, .json, .xml, .yaml, toml, SQLite, MySQL, SQL-Server and PostGreSQL files. In addition this library standardizes the process of setting and implementing log files. NOTE: Despite the fact that github shows the tests as failing, all tests do pass on a Linux and Mac platform before being uploaded to github. This issue appears to be caused by a library that while it works, was not written to be compatible with Python 3.11. We are working to fix this issue, but rest assure, the unit tests to pass.

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change. Please make sure to include and update tests as well as relevant doc-string and sphinx updates.

License

This project is licensed under a basic MIT License

Requirements

Python 3.8 or greater, developed with Python 3.11

Installation

In order to download this repository from github, follow these instructions

  1. Install poetry globally on your computer. Follow the instructions from the Poetry website

  2. Set the poetry virtual environment with the following command poetry config virtualenvs.in-project true

  3. Ensure you have .git installed on your computer.

  4. Open a terminal (Bash, zsh or DOS) and cd to the directory where you want to install the cobralib library

  5. Type git clone https://github.com/Jon-Webb-79/cobralib.git

  6. cd into the cobralib directory

  7. Create a virtual environment with the command python3 -m venv .venv

  8. Activate the virtual environment with the command source .venv/bin/activate

  9. Install packages. This library uses underlying packages to manage MySQL and PostGreSQL; however, each of these libraries requires that the user have MySQL and PostGreSQL servers installed locally on their machine

    • If the user does not have MySQL or PostGreSQL server installed on their machine type poetry install. This will install all packages other than the libraries for these two database management systems (DBMSs). Note, you will not be able to use the underlying functionality for these to DBMS’s.

    • If the user only has MySQL server installed locally, type poetry install -E mysql

    • If the user only has PostGreSQL installed locally, type poetry install -E postgresql

    • If the user has both MySQL and PostGreSQL installed locally, type poetry install -E mysql -E postgresql

    • If you plan to support development, install the read_the_doc sphinx package with pip, pip install sphinx_rtd_theme

  10. In the future this repository may also be available on PyPi

This package can also be installed via pip

  1. Install with all packages pip install cobralib

  2. Install with optional dependencies pip install 'cobralib[mysql, postgresql]'

Bug Report

  1. Despite the fact that the test suite passes on Mac and Linux, the Github tests appear to be failing due to a mismatch in libraries.

Future Work

  1. Strengthen unit testing for existing functions and classes

  2. Strenghten typing requirements for functions in io.py (yaml, json, xml, etc)

  3. Add support for Oracle RDBMS

  4. Add functionality for database backup for all db classes

  5. Add functionality for database migration for all db classes

  6. Consider C++ implementation for linked list and binary search trees

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

cobralib-0.2.0.tar.gz (31.0 kB view details)

Uploaded Source

Built Distribution

cobralib-0.2.0-py3-none-any.whl (29.6 kB view details)

Uploaded Python 3

File details

Details for the file cobralib-0.2.0.tar.gz.

File metadata

  • Download URL: cobralib-0.2.0.tar.gz
  • Upload date:
  • Size: 31.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.11.5 Linux/6.4.12-arch1-1

File hashes

Hashes for cobralib-0.2.0.tar.gz
Algorithm Hash digest
SHA256 8cbd6955b4f5aedf3e7d61c2bd0ccca419336d4c6a6f9502eeef2648408bca12
MD5 fa298f1aee1358154798d87372357a7f
BLAKE2b-256 e6ff7ea8f7b9a577036f51921e1f8ce04bb96110a885ef9e981f1e5eced485cd

See more details on using hashes here.

File details

Details for the file cobralib-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: cobralib-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 29.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.11.5 Linux/6.4.12-arch1-1

File hashes

Hashes for cobralib-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 370043e18fba3396b7621b6ee6ccd9e701c7109026d0cad01c35bcf34f2391ba
MD5 a2f680fe7a23206ef8a73331103e4a1c
BLAKE2b-256 10bbcab50ee9264b1025df2cb9ccd93f27fdc1faf6698424fcdc9602ff7a6dbc

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page