我不确定正确的术语是否是动态命名,但我希望我正在创建的文件的名称随着我列表中的股票行情而变化。
stocks_query = ['AAPL','OPK'] #current stocks I have in my list/tuple
stocks.to_pickle('\UsersMoondraMachineLearningstockPredictor-master{}.pkl'.format(stocks_query)) #stocks is a dataframe
产生如下结果:
['AAPL', 'OPK'].pkl
但我希望它更干净,并且正在寻找 aapl_opk.pkl
或AAPL_OPK.pkl
我玩了正则表达式,但我真的不知道完成这个任务。
re.findall(r'(w+)', str(stocks_query))
stocks.to_pickle('\UsersMoondraMachineLearningstockPredictor-master{}.pkl'.format(re.findall(r'(w+)', str(stocks_query))))
这会产生与上述相同的结果;当我命名我的文件时,我不知道如何将"_"放在股票名称之间。
谢谢。
编辑:
再玩一些,用元组
stocks_query = ('AAPL', 'OPK', 'GOOGL')
str(stocks_query)
>> "('AAPL', 'OPK', 'GOOGL')" , I was able to get this far using `re.sub`
x =re.compile(r'[)(]')
y = re.compile(r"[']")
re.sub(y, '_', re.sub(x, "", str(stocks_query))).replace(',', '')
这导致了AAPL_ _OPK_ _GOOGL_
理想输出为AAPL_OPK_GOOGL
Re 似乎是一个非常强大的工具,我觉得可以做我正在尝试做的事情,但我找不到合适的锚点/修饰符。
尝试以下操作:
stocks_query = ['AAPL', 'OPK', 'GOOGL']
filename = '_'.join(stock_query)
stocks.to_pickle('\UsersMoondraMachineLearningstockPredictor-master{}.pkl'.format(filename))