Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/flyanakin/CountMoney

A simple low-cost finance data pipeline orchestration. All you need is just python & SQL.
https://github.com/flyanakin/CountMoney

airtable-api dagster dbt etl finance modern-data-stack orchestration postgresql python sql stock tushare workflow

Last synced: about 2 months ago
JSON representation

A simple low-cost finance data pipeline orchestration. All you need is just python & SQL.

Awesome Lists containing this project

README

        

# CountMoney

## Overview

![image.png](doc/pic/overview.png?t=1674575257624)
A simple low-cost finance data pipeline orchestration. All you need is just python & SQL.
I compose the system of the following components, most of which are modern data stack components, meaning that the system is flexible and plug-and-play. You can switch to other components that you are familiar with. For example, in the EL part, you can switch to Airbyte or Fivetrans, etc. You can also write Python programs to transform your data. But note Dagster is the scheduling orchestration tool for this system. It is the foundation of this system. And you cannot replace it.

* datasources
* Finance data: [Tushare](https://tushare.pro/document/1) , a low-cost financial database, covering most Chinese stock market. If you purchase ¥500/yearly plan, you can use all api.
* Other data: [Airtable](https://airtable.com/), store some sensitive data , such as portfolio, costs, etc.
* extract & load: Ingestion as code, just write assets in orchestration code, and load data to postgres. IO logic is in ./resources/xxx_io_manager.py
* orchestration: Dagster cloud.
* Transformation: DBT.
* BI: Metadata, running on docker.
* Subcription
* wxwork webhook
* email

## Features

![image.png](doc/pic/GlobalAssetLineage.png)

### Pipeline Management

* Orchestrating daily job by software-defined asset.
* Manage assets.
* Launch a run whenever another job materializes a specific asset.

![image.png](doc/pic/Asset_events.png?t=1674573784793)

![image.png](doc/pic/Asset_plots.png)

![image.png](doc/pic/Asset_definition.png)

![image.png](doc/pic/Asset_lineage.png)

![image.png](doc/pic/Sensor.png)

### Visualization

![image.png](doc/pic/portfolio.png)

![image.png](doc/pic/preview.png)

### Subscription

![image.png](doc/pic/pushing.png)

## Models

* stock picks: all stock list with defence metrics and growth metrics
* performance: choose stocks with high growth from the stocks that released the performance forecast
* preview: choose stocks with high growth from the stocks that released the preview