当前位置:   article > 正文

PythonStock(13):使用stockstats计算股票中的16个常用指标方法大全

stockstats

前言

使用Python开发一个股票项目。
项目地址:
https://github.com/pythonstock/stock
相关资料:
http://blog.csdn.net/freewebsys/article/details/78294566
主要使用开发语言是python。
使用的lib库是pandas,tushare,TensorFlow,tornado等。

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/78578548
未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

计算股票中的16个常用指标方法大全

一个python的类库stockstats 已经帮忙把这些数据都计算出来了。
现在需要做的就是把这个数据展示出,分析下。每一个都是一个纬度分析的方法。
要一个一个的学习下。

主要指标有 CR指标 KDJ指标 SMA指标 MACD指标 BOLL指标 RSI指标 WR指标
CCI指标 TR、ATR指标 DMA指标 DMI,+DI,-DI,DX,ADX,ADXR指标
TRIX,MATRIX指标 VR,MAVR指标 等。
具体的计算代码不做分析,可以直接查看 stockstats 也是非常的简单的。
用几个 pandas 的函数就出来了。主要将的是使用方法。
具体使用效果需要慢慢使用才知道。

特别的感谢 http://wiki.mbalib.com/ 好多说明是从 mbalib上面查询到的。

pip install stockstats
  • 1

直接安装就行。
项目地址:https://github.com/jealous/stockstats

这个lib库和pandas 一样实现了下标访问的方式去计算。

    @classmethod
    def _get_kdjk(cls, df, n_days):
        """ Get the K of KDJ
        K = 2/3 × (prev. K) +1/3 × (curr. RSV)
        2/3 and 1/3 are the smooth parameters.
        :param df: data
        :param n_days: calculation range
        :return: None
        """
        rsv_column = 'rsv_{}'.format(n_days)
        k_column = 'kdjk_{}'.format(n_days)
        df[k_column] = list(cls._calc_kd(df.get(rsv_column)))
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

如果要计算数据 直接访问 stockStat[‘kdjk_3’] ,就可以制定使用 kdjk 指标,同时设置周期3天。参数传递方式特别有意思。很简单粗暴。用起来超级方便。

#开始计算。以平安银行为例:
#!/usr/local/bin/python
# -*- coding: utf-8 -*-

import math
import pandas as pd
import numpy as np
import tushare as ts
import datetime
import matplotlib.pyplot as plt
import stockstats

begin_time = '2017-02-01'
end_time = '2017-11-01'
code = "000001"
stock = ts.get_hist_data(code, start=begin_time, end=end_time)
stock["date"] = stock.index.values #增加日期列。
stock = stock.sort_index(0) # 将数据按照日期排序下。
#print(stock) [186 rows x 14 columns]
#初始化统计类
#stockStat = stockstats.StockDataFrame.retype(pd.read_csv('002032.csv'))
stockStat = stockstats.StockDataFrame.retype(stock)
print("init finish .")
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

1,delta 方法

没有找到 volume_delta 这个方法的实现。
原来调用是 key + “_delta” 去调用的。
超级方便。

# volume delta against previous day 
# The Volume Delta (Vol ∆) 
stockStat[['volume','volume_delta']].plot(figsize=(20,10), grid=True)
plt.show()
#交易量的delta转换。交易量是正,volume_delta把跌变成负值。
stockStat[['close','close_delta']].plot(subplots=True, figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

这里写图片描述

2,计算n天差

可以计算,向前n天,和向后n天的差。直接使用 key “n_d” 或 “-n_d” 。
如下图。向前和向后对涨跌的趋势判断不太一样。使用”_-n_d” 比较像原始数据的涨跌。

stockStat[
    ['close','close_1_d','close_2_d','close_-1_d','close_-2_d']
         ].plot(subplots=True, figsize=(20,10), grid=True)
plt.show()
# close_1_d  1 天的价差。 n天 - (n+1)天
# close_2_d  1 天的价差。 n天 - (n+2)天
# shift 函数是将数据 向前-n 向后+n 移动n天。 但是这个操作做了一个负值。
# 也就是 close_-1_d 才是和昨天的差 close_1_d 是和明天的差
#print(stockStat['close_-2_d'].head(10))
#print("stockStat['close']-stockStat['close'].shift(-1)")
#print((stockStat['close']-stockStat['close'].shift(-2)).head(10))
#print("############检查数据")
#print(stockStat['close'].head(10))
#print(stockStat['close'].shift(2).head(10))
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/78578548
未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

3,n天涨跌百分百计算

open price change (in percent) between today and the day before yesterday ‘r’ stands for rate.
stock[‘close_-2_r’]
可以看到,-n天数据和今天数据的百分比。

stockStat[
    ['close','close_-1_r','close_-2_r']
         ].plot(subplots=True, figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

4,CR指标

http://wiki.mbalib.com/wiki/CR%E6%8C%87%E6%A0%87
价格动量指标

  1. CR跌穿a、b、c、d四条线,再由低点向上爬升160时,为短线获利的一个良机,应适当卖出股票。
  2. CR跌至40以下时,是建仓良机。而CR高于300~400时,应注意适当减仓。
# CR indicator, including 5, 10, 20 days moving average
stockStat[
    ['close','cr','cr-ma1','cr-ma2','cr-ma3']
         ].plot(subplots=True, figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4
  • 5

5,KDJ指标

http://wiki.mbalib.com/wiki/%E9%9A%8F%E6%9C%BA%E6%8C%87%E6%A0%87

随机指标(KDJ)一般是根据统计学的原理,通过一个特定的周期(常为9日、9周等)内出现过的最高价、最低价及最后一个计算周期的收盘价及这三者之间的比例关系,来计算最后一个计算周期的未成熟随机值RSV,然后根据平滑移动平均线的方法来计算K值、D值与J值,并绘成曲线图来研判股票走势。

(3)在使用中,常有J线的指标,即3乘以K值减2乘以D值(3K-2D=J),其目的是求出K值与D值的最大乖离程度,以领先KD值找出底部和头部。J大于100时为超买,小于10时为超卖。

# KDJ, default to 9 days
stockStat[['close','kdjk','kdjd','kdjj'] # 分别是k d j 三个数据统计项。
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()

# three days KDJK cross up 3 days KDJD
# stockStat['kdjk_3_xu_kdjd_3'].plot(figsize=(20,10), grid=True)
# plt.show()
print(stockStat['kdjk_3_xu_kdjd_3'].tail())
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

6,SMA指标

http://wiki.mbalib.com/wiki/Sma
简单移动平均线(Simple Moving Average,SMA)

可以动态输入参数,获得几天的移动平均。

# 2 days simple moving average on open price
stockStat[['close','close_5_sma','close_10_sma'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

7,MACD指标

http://wiki.mbalib.com/wiki/MACD
平滑异同移动平均线(Moving Average Convergence Divergence,简称MACD指标),也称移动平均聚散指标

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/78578548
未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

MACD
stock[‘macd’]
MACD signal line
stock[‘macds’]
MACD histogram
stock[‘macdh’]

MACD技术分析,运用DIF线与MACD线之相交型态及直线棒高低点与背离现象,作为买卖讯号,尤其当市场股价走势呈一较为明确波段趋势时,
MACD 则可发挥其应有的功能,但当市场呈牛皮盘整格局,股价不上不下时,MACD买卖讯号较不明显。
当用MACD作分析时,亦可运用其他的技术分析指标如短期 K,D图形作为辅助工具,而且也可对买卖讯号作双重的确认。

# MACD 
stockStat[['close','macd','macds','macdh'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

8,BOLL指标

http://wiki.mbalib.com/wiki/BOLL
布林线指标(Bollinger Bands)

bolling, including upper band and lower band
stock[‘boll’]
stock[‘boll_ub’]
stock[‘boll_lb’]

1、当布林线开口向上后,只要股价K线始终运行在布林线的中轨上方的时候,说明股价一直处在一个中长期上升轨道之中,这是BOLL指标发出的持股待涨信号,如果TRIX指标也是发出持股信号时,这种信号更加准确。此时,投资者应坚决持股待涨。

2、当布林线开口向下后,只要股价K线始终运行在布林线的中轨下方的时候,说明股价一直处在一个中长期下降轨道之中,这是BOLL指标发出的持币观望信号,如果TRIX指标也是发出持币信号时,这种信号更加准确。此时,投资者应坚决持币观望。

# bolling, including upper band and lower band
stockStat[['close','boll','boll_ub','boll_lb'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

9,RSI指标

http://wiki.mbalib.com/wiki/RSI
相对强弱指标(Relative Strength Index,简称RSI),也称相对强弱指数、相对力度指数

6 days RSI
stock[‘rsi_6’]
12 days RSI
stock[‘rsi_12’]

(2)强弱指标保持高于50表示为强势市场,反之低于50表示为弱势市场。
(3)强弱指标多在70与30之间波动。当六日指标上升到达80时,表示股市已有超买现象,如果一旦继续上升,超过90以上时,则表示已到严重超买的警戒区,股价已形成头部,极可能在短期内反转回转。

(4)当六日强弱指标下降至20时,表示股市有超卖现象,如果一旦继续下降至10以下时则表示已到严重超卖区域,股价极可能有止跌回升的机会。

# 6 days RSI  12 days RSI
stockStat[['close','rsi_6','rsi_12'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

10,WR指标


http://wiki.mbalib.com/wiki/%E5%A8%81%E5%BB%89%E6%8C%87%E6%A0%87

威廉指数(Williams%Rate)该指数是利用摆动点来度量市场的超买超卖现象。


10 days WR
stock[‘wr_10’]
6 days WR
stock[‘wr_6’]

# 10 days WR 6 days WR
stockStat[['close','wr_10','wr_6'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

11,CCI指标

http://wiki.mbalib.com/wiki/%E9%A1%BA%E5%8A%BF%E6%8C%87%E6%A0%87

  顺势指标又叫CCI指标,其英文全称为“Commodity Channel Index”,
是由美国股市分析家唐纳德·蓝伯特(Donald Lambert)所创造的,是一种重点研判股价偏离度的股市分析工具。

CCI, default to 14 days
stock[‘cci’]
20 days CCI
stock[‘cci_20’]

  1、当CCI指标从下向上突破﹢100线而进入非常态区间时,表明股价脱离常态而进入异常波动阶段,
中短线应及时买入,如果有比较大的成交量配合,买入信号则更为可靠。

  2、当CCI指标从上向下突破﹣100线而进入另一个非常态区间时,表明股价的盘整阶段已经结束,
将进入一个比较长的寻底过程,投资者应以持币观望为主。

#  CCI, default to 14 days  20 days CCI
stockStat[['close','cci','cci_20'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

12,TR、ATR指标

http://wiki.mbalib.com/wiki/%E5%9D%87%E5%B9%85%E6%8C%87%E6%A0%87
均幅指标(Average True Ranger,ATR)

均幅指标(ATR)是取一定时间周期内的股价波动幅度的移动平均值,主要用于研判买卖时机。

TR (true range)
stock[‘tr’]
ATR (Average True Range)
stock[‘atr’]

均幅指标无论是从下向上穿越移动平均线,还是从上向下穿越移动平均线时,都是一种研判信号。

#  ATR (Average True Range)
stockStat[['close','tr','atr'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

13,DMA指标

http://wiki.mbalib.com/wiki/DMA

 DMA指标(Different of Moving Average)又叫平行线差指标,是目前股市分析技术指标中的一种中短期指标,它常用于大盘指数和个股的研判。

DMA, difference of 10 and 50 moving average
stock[‘dma’]

本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/78578548
未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

#   DMA, difference of 10 and 50 moving average
stockStat[['close','dma'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

14,DMI,+DI,-DI,DX,ADX,ADXR指标

http://wiki.mbalib.com/wiki/DMI

动向指数Directional Movement Index,DMI)

http://wiki.mbalib.com/wiki/ADX
平均趋向指标(Average Directional Indicator,简称ADX)

http://wiki.mbalib.com/wiki/%E5%B9%B3%E5%9D%87%E6%96%B9%E5%90%91%E6%8C%87%E6%95%B0%E8%AF%84%E4%BC%B0

平均方向指数评估(ADXR)实际是今日ADX与前面某一日的ADX的平均值。ADXR在高位与ADX同步下滑,可以增加对ADX已经调头的尽早确认。
ADXR是ADX的附属产品,只能发出一种辅助和肯定的讯号,并非入市的指标,而只需同时配合动向指标(DMI)的趋势才可作出买卖策略。
在应用时,应以ADX为主,ADXR为辅。

DMI
+DI, default to 14 days
stock[‘pdi’]
-DI, default to 14 days
stock[‘mdi]
DX, default to 14 days of +DI and -DI
stock[‘dx’]
ADX, 6 days SMA of DX, same as stock[‘dx_6_ema’]
stock[‘adx]
ADXR, 6 days SMA of ADX, same as stock[‘adx_6_ema’]
stock[‘adxr’]

#   DMI,+DI,-DI,DX,ADX,ADXR
stockStat[['close','pdi','mdi','dx','adx','adxr'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

15,TRIX,MATRIX指标

http://wiki.mbalib.com/wiki/TRIX
TRIX指标又叫三重指数平滑移动平均指标(Triple Exponentially Smoothed Average)

TRIX, default to 12 days
stock[‘trix’]
MATRIX is the simple moving average of TRIX
stock[‘trix_9_sma’]

# TRIX  MATRIX  
stockStat[['close','trix','trix_9_sma'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

16,VR,MAVR指标

http://wiki.mbalib.com/wiki/%E6%88%90%E4%BA%A4%E9%87%8F%E6%AF%94%E7%8E%87

成交量比率(Volumn Ratio,VR)(简称VR),是一项通过分析股价上升日成交额(或成交量,下同)与股价下降日成交额比值,
从而掌握市场买卖气势的中期技术指标。

VR, default to 26 days
stock[‘vr’]
MAVR is the simple moving average of VR
stock[‘vr_6_sma’]

# TRIX  MATRIX  
stockStat[['close','vr','vr_6_sma'] #
         ].plot(subplots=True,figsize=(20,10), grid=True)
plt.show()
  • 1
  • 2
  • 3
  • 4

计数count

使用 _c 计算数量,可以和其他的一起使用

#返回数量。
# close price less than 10.0 in 5 days count
print(stockStat['close_10.0_le_5_c'].tail())

#返回 True False 可以作为是否购买结果。
# CR MA2 cross up CR MA1 in 20 days count
print(stockStat['cr-ma2_xu_cr-ma1_20_c'].tail()) 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
date
2017-10-26    0.0
2017-10-27    0.0
2017-10-30    0.0
2017-10-31    0.0
2017-11-01    0.0
Name: close_10.0_le_5_c, dtype: float64
date
2017-10-26    False
2017-10-27    False
2017-10-30    False
2017-10-31    False
2017-11-01    False
Name: cr-ma2_xu_cr-ma1_20_c, dtype: bool
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

计算全部统计数据。

总结


本文的原文连接是: http://blog.csdn.net/freewebsys/article/details/78578548
未经博主允许不得转载。
博主地址是:http://blog.csdn.net/freewebsys

stockstats使用起来超级的方便。股票市场真的是个大熔炉,锻炼人。同时也要不断的学习。
学习股票中的数据分析,是python 的stockstats 可以很轻松的做到。
数据的分析报表的展示都非常容易。能够帮助股民快速的做出分析决策。
不放弃股票中的机会。
总之第一步先把这些数据计算出来。然后再做分析。

其他

计算全部统计数据。在 stockstats 里面有3个写错了,少分号啥的。

# volume delta against previous day
stockStat['volume_delta']

# open delta against next 2 day
stockStat['open_2_d']

# open price change (in percent) between today and the day before yesterday
# 'r' stands for rate.
stockStat['open_-2_r']

# CR indicator, including 5, 10, 20 days moving average
stockStat['cr']
stockStat['cr-ma1']
stockStat['cr-ma2']
stockStat['cr-ma3']

# volume max of three days ago, yesterday and two days later
stockStat['volume_-3,2,-1_max']

# volume min between 3 days ago and tomorrow
stockStat['volume_-3~1_min']

# KDJ, default to 9 days
stockStat['kdjk']
stockStat['kdjd']
stockStat['kdjj']

# three days KDJK cross up 3 days KDJD
#stock['kdj_3_xu_kdjd_3'] 这个写错了。
stockStat['kdjk_3_xu_kdjd_3']

# 2 days simple moving average on open price
stockStat['open_2_sma']

# MACD
stockStat['macd']
# MACD signal line
stockStat['macds']
# MACD histogram
stockStat['macdh']

# bolling, including upper band and lower band
stockStat['boll']
stockStat['boll_ub']
stockStat['boll_lb']

# close price less than 10.0 in 5 days count
stockStat['close_10.0_le_5_c']

# CR MA2 cross up CR MA1 in 20 days count
stockStat['cr-ma2_xu_cr-ma1_20_c']

# 6 days RSI
stockStat['rsi_6']
# 12 days RSI
stockStat['rsi_12']

# 10 days WR
stockStat['wr_10']
# 6 days WR
stockStat['wr_6']

# CCI, default to 14 days
stockStat['cci']
# 20 days CCI
stockStat['cci_20']

# TR (true range)
stockStat['tr']
# ATR (Average True Range)
stockStat['atr']

# DMA, difference of 10 and 50 moving average
stockStat['dma']

# DMI
# +DI, default to 14 days
stockStat['pdi']
# -DI, default to 14 days
stockStat['mdi'] #少了个单引号
# DX, default to 14 days of +DI and -DI
stockStat['dx']
# ADX, 6 days SMA of DX, same as stockStat['dx_6_ema']
stockStat['adx'] #少了个单引号
# ADXR, 6 days SMA of ADX, same as stockStat['adx_6_ema']
stockStat['adxr']

# TRIX, default to 12 days
stockStat['trix']
# MATRIX is the simple moving average of TRIX
stockStat['trix_9_sma']

# VR, default to 26 days
stockStat['vr']
# MAVR is the simple moving average of VR
stockStat['vr_6_sma']

#[5 rows x 95 columns]
#print(stockStat.head())
print(stockStat.columns.values)
print(len(stockStat.columns.values))
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101

打印出来全部的columns 信息。其中有些是临时的计算变量。

['open' 'high' 'close' 'low' 'volume' 'price_change' 'p_change' 'ma5'
 'ma10' 'ma20' 'v_ma5' 'v_ma10' 'v_ma20' 'turnover' 'volume_delta'
 u'open_2_s' u'open_2_d' u'open_-2_r' u'middle' u'cr' u'cr-ma1' u'cr-ma2'
 u'cr-ma3' u'volume_-3_s' u'volume_-1_s' u'volume_2_s'
 u'volume_-3,2,-1_max' u'volume_-2_s' u'volume_0_s' u'volume_1_s'
 u'volume_-3~1_min' u'rsv_9' u'kdjk_9' u'kdjk' u'kdjd_9' u'kdjd' u'kdjj_9'
 u'kdjj' u'rsv_3' u'kdjk_3' u'kdjd_3' 'kdjk_3_xu_kdjd_3' u'open_2_sma'
 u'close_26_ema' u'macd' u'macds' u'macdh' u'close_20_sma' u'close_20_mstd'
 u'boll' u'boll_ub' u'boll_lb' u'close_10.0_le' u'close_10.0_le_5_c'
 u'cr-ma1_20_c' 'cr-ma2_xu_cr-ma1_20_c' u'close_-1_s' u'close_-1_d' u'rs_6'
 u'rsi_6' u'rs_12' u'rsi_12' u'wr_10' u'wr_6' u'middle_14_sma' u'cci'
 u'middle_20_sma' u'cci_20' u'tr' u'atr' u'close_10_sma' u'close_50_sma'
 u'dma' u'high_delta' u'um' u'low_delta' u'dm' u'pdm' u'pdm_14_ema'
 u'pdm_14' u'atr_14' u'pdi_14' u'pdi' u'mdm' u'mdm_14_ema' u'mdm_14'
 u'mdi_14' u'mdi' u'dx_14' u'dx' u'dx_6_ema' u'adx' u'adx_6_ema' u'adxr'
 u'trix' u'trix_9_sma' u'change' u'vr' u'vr_6_sma']
99
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/362786
推荐阅读
相关标签
  

闽ICP备14008679号