Metadata-Version: 2.1
Name: funcat2
Version: 0.4.4a1
Summary: Funcat2保持与funcat兼容;Funcat 将同花顺、通达信、文华财经等的公式移植到了 Python 中。同花顺、通达信、文华财经麦语言等公式的表达十分简洁，适合做技术分析。苦于 Python 缺乏这种领域特定语言的表达能力，所以用 Python 基于 numpy 实现了一套。Funcat2增加QUANTAXIS的支持
Home-page: https://github.com/pchaos/funcat2
Author: Hua Liang, p19992003
Author-email: p19992003@gmail.com
License: Apache License v2
Platform: UNKNOWN
Classifier: Programming Language :: Python
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: Unix
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Description-Content-Type: text/markdown
License-File: LICENSE
Requires-Dist: numpy
Requires-Dist: six
Requires-Dist: pandas
Requires-Dist: lxml
Requires-Dist: requests
Requires-Dist: TA-Lib
Requires-Dist: cached-property
Requires-Dist: tqdm
Requires-Dist: py-singleton
Requires-Dist: backtrader
Requires-Dist: ipython

# Funcat2

[![PyPI](https://img.shields.io/pypi/v/funcat2.svg)](https://pypi.python.org/pypi/funcat2)
[![PythonVersion](https://img.shields.io/pypi/pyversions/funcat2.svg)](https://pypi.python.org/pypi/funcat2)
[![License](https://img.shields.io/pypi/l/funcat2.svg)](https://pypi.python.org/pypi/funcat2)

Funcat2保持与funcat兼容;

Funcat 将同花顺、通达信、文华财经等的公式移植到了 Python 中。

同花顺、通达信、文华财经麦语言等公式的表达十分简洁，适合做技术分析。

苦于 Python 缺乏这种领域特定语言的表达能力，所以用 Python 基于 numpy 实现了一套。

* Funcat2增加QUANTAXIS的支持

## 安装
```bash
pip install funcat2
# update funcat2
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple -U funcat2
```

## notebooks 教程
- [quick-start](https://github.com/pchaos/funcat2/blob/master/notebooks/funcat2-tutorial.ipynb)

## API
### 行情变量

- 开盘价：`OPEN` `O`
- 收盘价：`CLOSE` `C`
- 最高价：`HIGH` `H`
- 最低价：`LOW` `L`
- 成交量：`VOLUME` `V` `VOL`

### 工具函

- n天前的数据：`REF`
``` python
REF(C, 10)  # 10天前的收盘价
```

- 金叉判断：`CROSS`
``` python
CROSS(MA(C, 5), MA(C, 10))  # 5日均线上穿10日均线
```

- 两个序列取最小值：`MIN`
``` python
MIN(O, C)  # K线实体的最低价
```

- 两个序列取最大值：`MAX`
``` python
MAX(O, C)  # K线实体的最高价
```

- n天都满足条件：`EVERY`
``` python
EVERY(C > MA(C, 5), 10)  # 最近10天收盘价都大于5日均线
```

- n天内满足条件的天数：`COUNT`
``` python
COUNT(C > O, 10)  # 最近10天收阳线的天数
```

- n天内最大值：`HHV`
``` python
HHV(MAX(O, C), 60)  # 最近60天K线实体的最高价
```

- n天内最小值：`LLV`
``` python
LLV(MIN(O, C), 60)  # 最近60天K线实体的最低价
```

- 求和n日数据 `SUM`
``` python
SUM(C, 10)  # 求和10天的收盘价
```

- 求绝对值 `ABS`
``` python
ABS(C - O)
```

- 条件 `IF`
``` python
IF(OPEN > CLOSE, OPEN, CLOSE)
```

### 条件「和」与「或」
因为语法的问题，我们需要使用 `&` 代替 `and` 「和」，用 `|` 代替 `or` 「或」。

``` python
# 收盘价在10日均线上 且 10日均线在20日均线上
(C > MA(C, 10)) & (MA(C, 10) > MA(C, 20))

# 收阳线 或 收盘价大于昨收
(C > O) | (C > REF(C, 1))

```

### 指标

- 均线：`MA`
``` python
MA(C, 60)  # 60日均线
```

其他更多请见：[指标库](https://github.com/pchaos/funcat2/blob/master/funcat/indicators.py)


还有更多的技术指标还在实现中，欢迎提交pr一起实现。

## 自定义公式示例
[KDJ指标](http://wiki.mbalib.com/wiki/KDJ)。随机指标（KDJ）由 George C．Lane 创制。它综合了动量观念、强弱指标及移动平均线的优点，用来度量股价脱离价格正常范围的变异程度。

``` python
N, M1, M2 = 9, 3, 3

RSV = (CLOSE - LLV(LOW, N)) / (HHV(HIGH, N) - LLV(LOW, N)) * 100
K = EMA(RSV, (M1 * 2 - 1))
D = EMA(K, (M2 * 2 - 1))
J = K * 3 - D * 2

print(K, D, J)
```

[DMI指标](http://wiki.mbalib.com/wiki/DMI)。动向指数又叫移动方向指数或趋向指数。是属于趋势判断的技术性指标，其基本原理是通过分析股票价格在上升及下跌过程中供需关系的均衡点，即供需关系受价格变动之影响而发生由均衡到失衡的循环过程，从而提供对趋势判断的依据。

对于 DMI 这个指标，你会发现 TALib 算出来的结果，和同花顺等软件的结果不一样，我对比了下实现方式，发现，是因为同花顺的公式和 TALib 的计算公式不一样，对于这种情况，我们把同花顺的公式搬过来，就可以算出和同花顺一样的结果。

``` python
M1, M2 = 14, 6

TR = SUM(MAX(MAX(HIGH - LOW, ABS(HIGH - REF(CLOSE, 1))), ABS(LOW - REF(CLOSE, 1))), M1)
HD = HIGH - REF(HIGH, 1)
LD = REF(LOW, 1) - LOW

DMP = SUM(IF((HD > 0) & (HD > LD), HD, 0), M1)
DMM = SUM(IF((LD > 0) & (LD > HD), LD, 0), M1)
DI1 = DMP * 100 / TR
DI2 = DMM * 100 / TR
ADX = MA(ABS(DI2 - DI1) / (DI1 + DI2) * 100, M2)
ADXR = (ADX + REF(ADX, M2)) / 2

print(DI1, DI2, ADX, ADXR)
```

## 选股

``` python
from funcat import *


# 选出涨停股
select(
    lambda : C / C[1] - 1 >= 0.0995,
    start_date=20161231,
	end_date=20170104,
)

'''
[20170104]
20170104 000017.XSHE 000017.XSHE[深中华A]
20170104 000026.XSHE 000026.XSHE[飞亚达Ａ]
20170104 000045.XSHE 000045.XSHE[深纺织Ａ]
20170104 000585.XSHE 000585.XSHE[东北电气]
20170104 000595.XSHE 000595.XSHE[宝塔实业]
20170104 000678.XSHE 000678.XSHE[襄阳轴承]
...
'''


# 选出最近30天K线实体最高价最低价差7%以内，最近100天K线实体最高价最低价差大于25%，
# 最近10天，收盘价大于60日均线的天数大于3天
select(
    lambda : ((HHV(MAX(C, O), 30) / LLV(MIN(C, O), 30) - 1 < 0.07)
              & (HHV(MAX(C, O), 100) / LLV(MIN(C, O), 100) - 1 > 0.25)
              & (COUNT(C > MA(C, 60), 10) > 3)
             ),
    start_date=20161220,
)

'''
[20170104]
20170104 600512.XSHG 600512.XSHG[腾达建设]
[20170103]
[20161230]
20161230 000513.XSHE 000513.XSHE[丽珠集团]
...
'''


# 选出最近3天每天的成交量小于20日成交量均线，最近3天最低价低于20日均线，最高价高于20日均线
# 自定义选股回调函数
def callback(date, order_book_id, symbol):
    print("Cool, 在", date, "选出", order_book_id, symbol)


select(
    lambda : (EVERY(V < MA(V, 20) / 2, 3) & EVERY(L < MA(C, 20), 3) & EVERY(H > MA(C, 20), 3)),
    start_date=20161231,
    callback=callback,
)

'''
[20170104]
Cool, 在 20170104 选出 002633.XSHE 002633.XSHE[申科股份]
Cool, 在 20170104 选出 600857.XSHG 600857.XSHG[宁波中百]
...
'''
```

## 单股票研究
``` python
from funcat import *
from funcat.data.tushare_backend import TushareDataBackend

set_data_backend(TushareDataBackend())

# 设置目前天数为2017年1月4日
T("20170104")
# 设置关注股票为上证指数
S("000001.XSHG")

# 打印 Open High Low Close
>>> print(O, H, L, C)
3133.79 3160.1 3130.11 3158.79

# 当天涨幅
>>> C / C[1] - 1
0.0072929156356

# 打印60日均线
>>> MA(C, 60)
3154.78333333

# 判断收盘价是否大于60日均线
>>> C > MA(C, 60)
True

# 30日最高价
>>> HHV(H, 30)
3301.21

# 最近30日，收盘价 Close 大于60日均线的天数
>>> COUNT(C > MA(C, 60), 30)
17

# 10日均线上穿
>>> CROSS(MA(C, 10), MA(C, 20))
False
```

## DataBackend
* 默认实现了一个从 tushare 上面实时拉数据选股的 Backend。

*  [RQAlpha](https://github.com/ricequant/rqalpha) 的 Backend，使用它可以为我们提供本地的数据源，比从 tushare 拉数据速度更有优势。

``` bash
pip install rqalpha    # 安装依赖库 RQAlpha
rqalpha update_bundle  # 更新数据
```

替换 DataBackend 为 RQAlpha 的 DataProxy，这样可以从 RQAlpha 的 bundle 中获取数据。

``` python
from funcat.data.rqalpha_data_backend import RQAlphaDataBackend
from funcat import *

set_data_backend(RQAlphaDataBackend("~/.rqalpha/bundle"))
```
* [QUANTAXIS](https://github.com/QUANTAXIS/QUANTAXIS) 的Backend。
替换 DataBackend 为 QUANTAXIS  的 DataProxy，这样可以从 QUANTAXIS 中获取数据。

``` python
from funcat.data.quantaxis_backend import QuantaxisDataBackend as BACKEND
from funcat import *

set_data_backend(BACKEND())
```
为了更高的性能，您也可以自定义Backend使用本地数据。这样可以极大地提高运行速度。

## git开发流程：
### 开发分支
```bash
git clone https://github.com/pchaos/funcat2.git
cd funcat2
pip install QUANTAXIS
git chechkout dev 
# ... do your self
```
### 提交开发到master分支
```bash
git checkout master
git merge dev
git push
git checkout dev

# 一句话执行
git push && git checkout master && git merge dev && git push && git checkout dev
```
### 不用每次输入密码，设置https为ssh登录
> git remote set-url origin git@github.com:pchaos/funcat2.git

* PS：上面的“pchaos”使用你的用户名

