使用python实现短线选股

经常做短线的朋友都知道,选股是个较为复杂的工作,尤其是像我们这种非职业选手,下面就分享一些通过python实现选股的思路。
在这里插入图片描述

股票信息获取

炒短线离不开龙虎榜,我们先来通过龙虎榜来进行股票选择

url = 'https://applhb.longhuvip.com/w1/api/index.php'
    headers = {
        'user-agent':'Mozilla/5.0(Linux; Android 7.1.2; SM-G955N Build/NRD90M.G955NKSU1AQDC; wv)'
    }
    # POST请求参数
    params = {
        'st': '500',
        'Index': '0',
        'c': 'LongHuBang',
        'PhoneOSNew': 1,
        'a': 'GetStockList',
        'DeviceID': '0f6ac4ae-370d-3091-a618-1d9dbb2ecce0',
        'apiv': 'w31',
        'Type': 2,
        'UserID': 0,
        'Token': 0,
        'Time': 0,
    }
    # 发送POST请求
    response = requests.post(url, params=params, headers=headers)
    # 将编码设置为当前编码
    response.encoding = response.apparent_encoding
    # 解析JSON数据
    data = json.loads(response.text)
    # 获取买入营业部、卖出营业部和风口概念等数据
    BIcon = data.get('BIcon')
    SIcon = data.get('SIcon')
    fkgn = data.get('fkgn')
    lb = data.get('lb')
    all_data_list = []
    # 遍历股票列表,提取数据
    for item in data.get('list'):
        ID = item.get('ID')
        item_data = [
            ID,
            item.get('Name'),
            item.get('IncreaseAmount'),
            item.get('BuyIn'),
            item.get('JoinNum'),
            ','.join(BIcon.get(ID, [])),
            ','.join(SIcon.get(ID, [])),
            ','.join(fkgn.get(ID, {}).values()),
            lb.get(ID),
        ]

        # 将数据转换成DataFrame类型
        sample_data = pd.DataFrame(item_data).T
        column_dict = {
            0: '股票代码',
            1: '股票名称',
            2: '涨幅',
            3: '净买入',
            4: '关联数',
            5: '买入营业部',
            6: '卖出营业部',
            7: '风口概念',
            8: '连板数'
        }
        sample_data.rename(columns=column_dict, inplace=True)
        all_data_list.append(sample_data)
    # 返回DataFrame类型数据
    all_data = pd.concat(all_data_list)

这个时候我们就拿到了我们想要的数据

     股票代码   股票名称  ...                                               风口概念   连板数
0  600895   张江高科  ...  光刻机,蚂蚁金服概念,芯片,上海,REITs,地产链,创投,中报增长,业绩增长,汽车类,新能源汽车  None
0  002194   武汉凡谷  ...  5G,滤波器,芯片,华为概念,人工智能,ST摘帽,武汉,教育,智能驾驶,毫米波雷达,通信,C...  None
0  000766   通化金马  ...  阿尔茨海默,医药,创新药,肝炎概念,中药,大麻,医美,民营医院,超跌,并购重组,中报增长,业绩增长     4
0  002229   鸿博股份  ...  英伟达概念,ChatGPT,虚拟人,服务器,元宇宙,华为概念,人工智能,海南,包装印刷,世界...  None

这个时候我们就拿到了龙虎榜的基础信息

进一步信息获取

龙虎榜上的信息有限,我们可以进一步获取到信息。

def get_dea_info(certificate_id):
    exchange_list = [
        'sh',
        'sz',
    ]
    now_time = get_now_time()
    year, month, date = now_time.split("-")
    start_month = month[-1] if "0" in month else month
    start_month = int(start_month) - 1
    start_month = str(start_month) if start_month > 9 else f"0{start_month}"
    end_date = f'{year}-{month}-{date}'
    start_date = f'{year}-{start_month}-{date}'
    print(start_date)
    print(end_date)
    have_search_info = False
    for exchange in exchange_list:
        rs = bs.query_history_k_data(f"{exchange}.{certificate_id}",
                                     "date,code,open,high,low,close,preclose,volume,amount,adjustflag,turn,tradestatus,pctChg,peTTM,pbMRQ,psTTM,pcfNcfTTM,isST",
                                     start_date=start_date,
                                     end_date=end_date,
                                     frequency="d", adjustflag="3")
        detail_data_list = []
        while (rs.error_code == '0') & rs.next():  # 获取一条记录,将记录合并在一起
            detail_data_list.append(rs.get_row_data())
        if detail_data_list:
            have_search_info = True
            break

    if have_search_info:
        result = pd.DataFrame(detail_data_list, columns=rs.fields)
        for count_rs in ['open', 'high', 'low', 'close']:
            result[count_rs] = result.apply(
                lambda x: get_percentage(x, count_rs), axis=1
            )
        result['turn'] = result['turn'].apply(lambda x: x[:5])
    result = result.sort_values(by='date', ascending=False)
    return result

这样我们就拿到了个股最新一个月的量价信息

          date       code  open   high  ...     pbMRQ     psTTM  pcfNcfTTM isST
21  2023-09-15  sz.002889  5.74  10.02  ...  2.256259  1.842298  21.709520    0
20  2023-09-14  sz.002889 -1.19  10.02  ...  2.050822  1.674554  19.732829    0
19  2023-09-13  sz.002889 -3.15   0.53  ...  1.863981  1.521993  17.935063    0
18  2023-09-12  sz.002889  0.55   6.99  ...  1.855126  1.514763  17.849860    0
17  2023-09-11  sz.002889  0.92   1.26  ...  1.786057  1.458366  17.185283    0
16  2023-09-08  sz.002889  0.96   9.99  ...  1.832989  1.496687  17.636855    0
15  2023-09-07  sz.002889 -0.05  -0.05  ...  1.666514  1.360756  16.035054    0

策略书写

后面就是策略选股了
比如我们要进行选股了,我们想做连板票,我们搜素一下未放量,且最近一个月没有前高的票

def search_strategy_result(sample_data):
    # 我们筛选涨停票, 且没有放巨量, 之前也未放过巨量的
    recently = sample_data.iloc[0]
    # 判断当天是否涨停
    close = float(recently['close'])
    if float(recently['pctChg']) < 9.6:
        return False
    # 判断一个月内是否有前高
    max_high = float(sample_data['high'].max())
    if close < max_high:
        return False
    # 判断换手率是否超过15
    if float(recently['turn']) > 15.0:
        return False
    # 相比前一天是否放量
    turn_ration = float(recently['turn']) / float(sample_data.iloc[1]['turn'])
    if turn_ration > 1.5:
        return False
    return True

结果

通化金马  000766 符合策略已入库
东方嘉盛  002889 符合策略已入库
泉阳泉  600189 符合策略已入库
龙江交通  601188 符合策略已入库
路桥信息 未查询到信息
2023-09-17龙虎榜共有43只股票4只股票符合要求

本文章只是技术分享,不能作为投资建议

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 双龙战法是一种常用于股票投资的选股策略,主要是根据股票的涨跌趋势来进行买卖决策。下面是使用 Python 实现股票双龙战法选股策略的基本步骤: 1. 数据获取:使用 Python 的 tushare 库等工具获取股票数据,包括股票的历史价格、涨跌幅等信息。 2. 龙头股选取:根据股票的涨跌幅等指标,选取近期涨幅较大、市值较高、行业地位较好的股票作为“龙头股”。 3. 热点板块选取:根据当前市场的行情,选取热点板块,例如近期受到市场关注的新能源汽车、芯片等板块。 4. 买卖信号判断:根据选取的龙头股和热点板块的涨跌幅变化情况,判断是否出现买入或卖出的信号。具体判断逻辑可以根据实际情况进行调整,例如可以根据股票的均线、MACD等指标进行判断。 5. 买卖操作:根据买卖信号进行买卖操作。对于买入操作,可以根据股票的市价和可用资金进行买入;对于卖出操作,可以根据股票的当前持仓数量进行卖出。 以下是一个简单的 Python 示例代码,用于实现股票双龙战法选股策略: ```python import tushare as ts # 获取股票历史数据 stock_code = '600519' # 茅台股票代码 df = ts.get_k_data(stock_code) # 选取近期涨幅较大的股票作为“龙头股” dragon_stock = df[df['close'] > df['close'].shift(1)].iloc[-1]['code'] # 选取热点板块 hot_industry = ['新能源汽车', '芯片'] # 根据龙头股和热点板块判断买卖信号 buy_signal = False sell_signal = False if df.iloc[-1]['code'] == dragon_stock and df.iloc[-1]['industry'] in hot_industry: if df.iloc[-1]['close'] > df.iloc[-1]['ma5'] and df.iloc[-1]['close'] > df.iloc[-1]['ma10']: buy_signal = True elif df.iloc[-1]['close'] < df.iloc[-1]['ma5'] and df.iloc[-1]['close'] < df.iloc[-1]['ma10']: sell_signal = True # 根据买卖信号进行买卖操作 if buy_signal: # 根据当前资金和股票市价 ### 回答2: 股票双龙战法是一种常用的股票选股策略,其基本原理是结合龙头和龙尾股票进行选股操作。Python是一种强大的编程语言,可以用于实现股票双龙战法选股策略。 首先,我们需要获取股票的历史数据,并对数据进行处理和分析。可以使用Python中的第三方库,如pandas和numpy,来处理和分析股票数据。通过计算每只股票的涨幅和成交量等指标,可以确定股票的龙头和龙尾。 接下来,我们可以根据双龙战法的规则进行选股。一般来说,选择龙头股票时,可以通过筛选涨幅较大、成交量较高、市值较大的股票来确定。而选择龙尾股票时,可以通过筛选跌幅较大、成交量较低的股票来确定。 在Python中,可以使用条件语句和循环语句来实现选股策略的判断和操作。通过编写相应的筛选条件和规则,可以自动筛选出符合双龙战法选股策略的股票。 最后,根据选股结果,可以进行进一步的分析和决策。可以通过绘制股票的K线图、计算技术指标等方式来进行分析,以确定实际的买入和卖出时机。 总之,Python可以通过使用第三方库和编写相应的代码来实现股票双龙战法选股策略。通过对股票数据的处理与分析,以及根据选股规则进行筛选,可以自动化地选出符合双龙战法的股票,为投资者提供辅助决策。 ### 回答3: 股票双龙战法是一种基于技术分析的选股策略,通过使用Python编程语言实现,可以更加高效地筛选出符合双龙战法的股票。 首先,我们需要使用Python的数据获取库来获取股票的历史数据,如pandas-datareader或tushare。然后,我们可以使用Python的数据处理库,如pandas,来对数据进行清洗和整理。 接下来,我们需要实现双龙战法的具体规则。双龙战法一般包含两个指标:均线和MACD指标。 对于均线指标,我们可以使用Python的技术分析库,如ta-lib,来计算不同周期的移动平均线,并筛选出股票当日收盘价在均线之上的股票。 对于MACD指标,我们可以使用Python的技术分析库,如ta-lib,来计算MACD线、信号线和柱状线的数值,并根据双龙战法的规则,筛选出金叉买入和死叉卖出的股票。 在实现策略的过程中,我们还可以结合其他指标和条件,如成交量、相对强弱指标(RSI)等,来进一步优化选股策略。 最后,我们可以使用Python的可视化库,如matplotlib或seaborn,来绘制选股策略的交易信号和收益曲线,以便进行策略的回测和评估。 通过使用Python实现股票双龙战法选股策略,我们可以更加灵活和快速地应用该策略,并能够根据实际情况进行调整和优化,提高选股的准确性和效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值