(同花顺量化)规模2亿以上_、按个股热度从大到小排序名、振幅大于1

用户头像神盾局量子研究部
2023-08-31 发布

问财量化选股策略逻辑

选股逻辑为:振幅大于1、按个股热度从大到小排序、规模2亿以上。将选股逻辑作为第一个标题放入段落中。

选股逻辑分析

该选股策略的逻辑如下:

  1. 振幅大于1:表示该股票市场交易活跃度较高;
  2. 按照个股热度进行排序:表示在符合条件下按照市场的热度进行排序,选择市场认可度高的个股;
  3. 规模2亿以上:表示选股的股票具有一定的市值,较为稳定。

基于以上选择条件,可以筛选出市场认可度高、市值较大且交易活跃的股票,有助于提高投资回报和降低风险。

有何风险?

该选股策略可能存在以下风险:

  1. 仅根据股票市值和交易活跃度做出股票选择,没有考虑公司未来的业绩增长潜力和市场竞争力等因素,存在盲目跟风选股的风险;
  2. 挑选出来的股票可能会在未来出现行情变化,造成持仓风险;
  3. 挑选区间窄,不适合长期持有,存在较高的操作风险。

如何优化?

为了提高选股的准确性和降低风险,可以从以下方面进行优化:

  1. 除了市值和交易活跃度外,考虑引入其他财务指标如ROE、毛利率等进行评估,综合考虑股票的价值潜力和风险;
  2. 考虑到股票价格的波动以及未来的行情变化,可以引入技术指标和策略进行辅助分析,避免单一因素影响选股判断;
  3. 建议选择相对稳健的证券,避免主动型资产配置风险。

最终的选股逻辑

综合以上分析和优化,我们最终的选股逻辑为:
在符合振幅大于1、按个股热度从大到小排序、规模2亿以上的条件下,引入其他财务指标进行综合评估和分析,综合价值和风险考虑选出符合长期投资的个股,并进行相应的持有操作。在操作上,考虑到市场波动,进行定期的卖出操作,并及时调整策略,避免风险。

同花顺指标公式代码参考

该策略可引入以下指标进行辅助分析:

  1. 振幅指标:
    振幅:
((HIGH-LOW)/REF(CLOSE,1))>0.01
  1. 个股热度指标:
    个股热度指标:
SORT_BY_DESC(stock_heat/)
  1. 规模指标:
    规模:
TVAL>2e9

python代码参考

以下是使用Python进行选股的代码实现示例:

import pandas as pd
import tushare as ts
from pyecharts.charts import *
from pyecharts.options import *

# 获取符合条件的股票代码
def get_selected_codes():
    codes = ts.get_today_all()["code"].tolist()
    selected_codes = []
    for code in codes:
        df = ts.get_stock_basics()
        name = df.loc[code]["name"]
        if code.startswith("ST"):
            continue
        if df.loc[code]["totals"]*df.loc[code]["price"] < 2e9:
            continue
        df_daily = ts.get_hist_data(code)
        if df_daily.empty or (len(df_daily) < 252):
            continue
        if (df_daily.iloc[-1]["high"] - df_daily.iloc[-1]["low"]) / df_daily.iloc[-1]["open"] > 0.01:
            df_gzxg = ts.get_today_all()
            yesterday_close = df_gzxg[df_gzxg["code"]==code]["settlement"].values[0]
            if ((df_daily.iloc[-2]["high"] > yesterday_close * 1.098) or (df_daily.iloc[-2]["low"] < yesterday_close)):
                continue
            selected_codes.append(code)
    stock_heat_dict = {}
    for code in selected_codes:
        df = ts.get_realtime_quotes(code)
        stock_heat = int(df["volume"]) * float(df["price"])
        stock_heat_dict[code] = stock_heat
    sorted_stock_heat = sorted(stock_heat_dict.items(), key=lambda x: x[1], reverse=True)
    selected_codes = [x[0] for x in sorted_stock_heat[:100]]
    return selected_codes

# 获取股票基本面数据
def get_stocks_info(codes):
    info_dict = {}
    for code in codes:
        df = ts.get_stock_basics()
        name = df.loc[code]["name"]
        info_dict[name] = {
            "industry": df.loc[code]["industry"], 
            "area": df.loc[code]["area"], 
            "pe": df.loc[code]["pe"],
            "pb": df.loc[code]["pb"]
        }
    return info_dict

# 选股策略
def stock_selection():
    selected_codes = get_selected_codes()
    selected_info = get_stocks_info(selected_codes)
    return selected_info

# 可视化展示
def show(selected_info):
  data = []
  for name, info in selected_info.items():
    data.append((name, info["industry"], info["area"], info["pe"], info["pb"]))
  # 绘制表格
  chart = (
      Table()
      .add(headers=["股票名称", "行业", "地区", "市盈率", "市净率"], rows=data)
      .set_global_opts(title_opts=opts.ComponentTitleOpts(title="股票挑选结果"))
  )
  return chart

# 选出符合条件的股票
selected_info = stock_selection()
print("符合条件的股票:", selected_info)

# 展示结果
chart = show(selected_info)
chart.render()

其中,在代码中需要根据实际需求进行相应的设置。

    ## 如何进行量化策略实盘?
    请把您优化好的选股语句放入文章最下面模板的选股语句中即可。

    select_sentence = '市值小于100亿' #选股语句。

    模板如何使用?

    点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。


    ## 如果有任何问题请添加 下方的二维码进群提问。
    ![94c5cde12014f99e262a302741275d05.png](http://u.thsi.cn/imgsrc/pefile/94c5cde12014f99e262a302741275d05.png)
收益&风险
源码

评论

需要帮助?

试试AI小助手吧