A toolbox for Analytics and Research.
Project description
Title
summary
%load_ext autoreload
%autoreload 2
Welcome to analytics_toolbox
aka atb
Enabling Data Scientists to amplify their inner Data Engineer.
A toolbox for managing data coming from multiple Postgres, Redshift & S3 data sources while performing Analytics and Research. We also have some functionality that help users build Slack Bots.
Install Us
pip install analytics_toolbox
Documentation
Our docs are currently useless as of 2020-02-12.
Vote For Change!
I'll see your comments on GitHub.
Support Us
Coming someday, maybe?
Do You Know About config Files?
analytics_toolbox
is only made possible by its reliance on standardized credential storage. You wanna use us, you sadly must play by some of our rules.
We read and build classes via the variable names in the config files you pass to our code. Trust us. Its worth it. You'll end up saving 100s of lines of code by simply passing 1 to 2 arguments when instantiating our primary classes.
Config Files are a great way to store information. We chose this over other options like json or OS level environment variables for no clear reason. If you really want support for other credential formats, vote with your words here.
Config File Format Guidelines
Postgres + Redshift Connections
If your config file section has a hostname
, port
, database
and user
sections, then we'll parse it as a Redshift/Postgres database. You store your password in .pgpass
(see below if this is new).
Here is an example of Postgres/Redshift entries.
"
"
[dev_db]
hostname = dev.yourhost.com
port = 5432
database = dbname
user = htpeter
[prod_db]
hostname = prod.yourhost.com
port = 5432
database = dbname
user = htpeter
What is .pgpass?
When python's psycopg2
or even psql
attempt to connect to a server, they will look in a file called ~/.pgpass
. If they find matching server information, based on the target they are connecting to, they use that password.
~/.pgpass
's format is simple. Include a line in the file that follows the following format.
hostname:port:database:username:password
Ensure you limit the permissions on this file using chmod 600 ~/.pgpass
, otherwise no tools will use it due to its insecurity.
You don't pass database passwords to analytics_toolbox
. Instead we leverage pgpass. Simply paste a record for each database in a text file ~/.pgpass
with the following information.
Slack Connections
Our Slack APIs use Slack Bot OAuth Tokens.
Create an OAuth token and save it to a variable called bot_user_oauth_token
. You can store the token in a config section named whatever you want.
[company_slack]
oauth_token = 943f-1ji23ojf-43gjio3j4gio2-2fjoi23jfi23hio
[personal_slack]
oauth_token = 943f-dfase3-basf234234-fw4230kf230kf023k023
Usage Examples
Querying Multiple Databases & Moving Data
Our import is both useful and classy enough to be jammed up at the top with yourpd
s, np
s and plt
s.
import analytics_toolbox as atb
And then you simply create a database pool object with your Config File. It loads up all the goodies.
db = atb.DBConnector('../atb_config_template.ini')
db
{ 'dev_db': <analytics_toolbox.connector.DatabaseConnection object at 0x11698bc88>,
'prod_db': <analytics_toolbox.connector.DatabaseConnection object at 0x1169d8198>}
Now we can query any of our databasese easily!
# reference with the config file keyname
db['dev_db'].qry('select * from pg_class limit 5')
db['prod_db'].qry('select * from pg_class limit 5')
# or if config file section is pythonic, use its name just like pandas!
db.dev_db.qry('select * from pg_class limit 5')
db.prod_db.qry('select * from pg_class limit 5')
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
Built Distribution
Hashes for analytics_toolbox-0.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c315d067cfad8ef27d7155db00bff7025e7f3439bcc1d446311e0f03cfa9b3ac |
|
MD5 | 8ba002f4367cbac29190a7ee516b5304 |
|
BLAKE2b-256 | 56dda5195f09045e767c0a4ed914a416d137c4ff3829ae0a11dac2a7ade6c053 |