Metadata-Version: 2.1
Name: pybase-db
Version: 1.0.0.dev6
Summary: PyBase is a manager for NoSQL and SQLite3 databases. Very fast, powerful, simple and effective.
Home-page: https://pybase.netlify.app/
Author: PyBase Team
Author-email: bloodbathalchemist@protonmail.com
License: MIT
Keywords: database,manager,NoSQL,SQL
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Topic :: Database
Classifier: Topic :: Database :: Database Engines/Servers
Classifier: Topic :: Software Development :: Libraries
Description-Content-Type: text/markdown
Requires-Dist: psutil (>=5.8.0)
Requires-Dist: pyyaml (>=5.4.1)
Requires-Dist: toml (>=0.10.2)

![PyBase](https://socialify.git.ci/PyBase/PyBase/image?description=1&descriptionEditable=Python%20Manager%20for%20NoSQL%20and%20SQLite3%20databases.&font=Inter&forks=1&issues=1&logo=https%3A%2F%2Fiili.io%2FFEHkLg.png&pattern=Circuit%20Board&stargazers=1&theme=Light)

[![Netlify Status](https://api.netlify.com/api/v1/badges/6a03656b-b3f4-4a90-a52d-9f8d176d6a28/deploy-status)](https://app.netlify.com/sites/pybase/deploys)
![Python Versions](https://img.shields.io/pypi/pyversions/pybase-db)
![Version](https://img.shields.io/pypi/v/pybase-db?color=green&label=version)
[![Downloads](https://pepy.tech/badge/pybase-db)](https://pepy.tech/project/pybase-db)
[![Discord](https://img.shields.io/discord/779841556215627776?color=008aff&label=support&logo=discord&style=flat-square)](https://discord.gg/4BC8RqYxGc)
![License](https://img.shields.io/pypi/l/pybase-db)

PyBase is a DataBase Manager for NoSQL and SQLite3.

It's focused on the ease and effectiveness for the administration of databases.

---

## Why PyBase?

If you want to store static data (NoSQL) or store a database in SQLite3,
**the best thing would be to use an administrator that simplifies your tasks and
helps you with a good organization and efficiently.**

**PyBase does exactly that, allows you to create such databases with
just one method, and simplifies the task of manipulating their data!**

---

## Contribuitors

<a href="https://github.com/PyBase/PyBase/graphs/contributors">
  <img src="https://contrib.rocks/image?repo=PyBase/PyBase" />
</a>

Made with [contributors-img](https://contrib.rocks).

---

# Quick start

## Installation

PyBase requires Python 3.6 onwards and can be installed through `pip` with the following command.

> Note: If you plan to install pybase system-wide instead of current user make sure you have admin permissions.

```sh
# Stable version
python3 -m pip install -U pybase_db

# Pre-release (Development) version
python3 -m pip install -U --pre pybase_db

# From github's latest commit
# Available branches:
#   • master (recommended)
#   • development (unstable releases)
# NOTE: this installation mode will not install PyBase external dependencies!
python3 -m pip install -U git+https://github.com/PyBase/PyBase@branch
```

### Building

The development branch changes aren't compiled and uploaded to Pypi every time,
so you must compile a wheel yourself to test the experimental stuff if the newest
changes aren't uploaded to Pypi.

```sh
# Without make
python3 setup.py install

# Write less, do more!
make install
```

## Usage example

This is a brief example of the methods that PyBase currently has.

```py
# Lets import PyBase Class from PyBase Package
from pybase_db import PyBase

# Lets define our database name and format (with default db_path).
# db_type isn't case sensitive. You can use JSON and json and it'll be valid.
db = PyBase(database="example", db_type="JSON")  # => ./example.json

# Lets define and add some content to our database.
pybase_info = {"pybase": "awesomeness", "version": "1.0.0"}

# Lets insert the defined dict inside our database.
db.insert(pybase_info,
          mode="w")  # => {'pybase': 'awesomeness', 'version': '1.0.0'}

# Lets delete an object inside our database cuz it's useless.
db.delete('pybase')  # => {'version': '1.0.0'}

# Lets insert more data cuz that's funny!
db.insert(content={"guilds": {}, "ownerID": 1234567890}, mode="w")

# Lets insert some data inside the guilds key
db.insert(content={
    "guilds": {
        "12345": {
            "name": "First guild"
        },
        "67890": {
            "name": "Second guild"
        }
    }
},
          mode="a")

# Lets fetch an object inside our database and display its type.
# It's useful to debug and manipulate the data dynamically.
db.fetch('version')  # => <class 'str'>

# Gets the corresponding value according to the specified key
db.get("version")  # => '1.0.0'

# New data of the new update
pybase_update = {"pybase": {"newVersion": {"version": "1.0.0"}}}
db.insert(pybase_update)

# Get all data from db
db.get()  # => {'pybase': {'newVersion': {'version': '1.0.0'}}, 'version': '1.0.0'}

# Get the values using its key
db.get("pybase")  # => {'newVersion': {'version': '1.0.0'}}

# Get a value of a key separated by a period (.)
db.get("pybase.newVersion")  # => {'version': '1.0.0'}

# Several
db.get("pybase.newVersion.version")  # => 1.0.0
```

> **You can see more examples [here](./examples)**

## Benchmark

PyBase is made to be fast, and what better proof than a benchmarking test?

You can see the code used for the test and the results in [benchmark](./tests/benchmark/README.md#results).

## Documentation

You can see the PyBase documentation through the `help()` function of the REPL
and through the [official documentation site](https://pybase.netlify.app/docs/).

## Changelog

You can see the PyBase changelog [here](./CHANGELOG.md)

---

# License

**PyBase is distributed under [MIT License](./LICENSE).**

# Contributing

You can see how to contribute [here](./CONTRIBUTING.md)

# Code of Conduct

You can see the code of conduct [here](./CODE_OF_CONDUCT.md)


