Я сделал что-то похожее в Bash , но не уверен, как это сделать в 2-3 сжатых строках Ruby, хотя кажется, что это можно сделать в одно мгновение с правильным кодированием Kung-Fu .
У меня есть "file.csv" со строкой заголовка, которая выглядит следующим образом:
Ticker,"Price","Market Cap","Average Volume","Analyst Recom","Relative Strength Index (14)","Sector","Industry","Dividend Yield","Beta","52-Week Low","52-Week High","50-Day Low","50-Day High","Company","50-Day Simple Moving Average","Country","P/E","Forward P/E","PEG","P/S","P/B","P/Cash","P/Free Cash Flow","Payout Ratio","EPS (ttm)","EPS growth this year","EPS growth next year","EPS growth past 5 years","EPS growth next 5 years","Sales growth past 5 years","EPS growth quarter over quarter","Sales growth quarter over quarter","Shares Outstanding","Shares Float","Insider Ownership","Insider Transactions","Institutional Ownership","Institutional Transactions","Float Short","Short Ratio","Return on Assets","Return on Equity","Return on Investment","Current Ratio","Quick Ratio","LT Debt/Equity","Total Debt/Equity","Gross Margin","Operating Margin","Profit Margin","Performance (Week)","Performance (Month)","Performance (Quarter)","Performance (Half Year)","Performance (Year)","Performance (Year)","Average True Range","Volatility (Week)","Volatility (Month)","20-Day Simple Moving Average","200-Day Simple Moving Average","Change from Open","Gap","Relative Volume","Change","Volume","Earnings Date","No."
сопровождается примерно 7000 строк, которые выглядят так:
FCD,27.89,,0.94,,66.75,"Financial","Exchange Traded Fund",3.13%,,19.75%,-0.36%,6.37%,-0.36%,"Focus Morningstar Consumer Defensive ETF",2.28%,"USA",,,,,,,,,,,,,,,,
,,,,,,,,,,,,,,,,,,,0.36%,3.07%,9.93%,10.85%,,2.01%,0.12,0.04%,0.21%,1.26%,6.69%,0.00%,-0.04%,0.96,-0.04%,900,,2186
FCE-A,14.59,2496.64,960.33,2.50,54.76,"Financial","Property Management",,2.83,56.55%,-24.87%,36.61%,-7.77%,"Forest City Enterprises Inc.",11.49%,"USA",,69.48,,2.2
5,1.58,10.87,,,-0.02,410.77%,250.00%,-10.06%,8.00%,1.54%,-28.77%,-9.00%,171.12,136.94,0.26%,-8.25%,74.80%,-0.13%,4.62%,6.59,0.46%,-0.12%,0.54%,,,4.35,4.35,39.54%,
4.82%,4.60%,-4.01%,8.96%,25.45%,13.10%,-22.80%,23.43%,0.44,3.07%,2.98%,-0.89%,1.49%,-1.62%,0.00%,0.47,-1.62%,449874,12/8/2010 4:30:00 PM,2187
Учитывая символ тикера "FCD", я пытаюсь присвоить массам около 30 новых переменных, взятых из полей заголовка, значениям, соответствующим строке "FCD".
Каждая новая переменная должна начинаться с префикса fv_
и иметь остаток как в названии поля минус все знаки препинания, пробелы, кавычки и т. Д. (Переменные-недружественные данные).
Так что для "FCD" я пытаюсь дать свой сценарий:
fv_Ticker="FCD"
fv_Price=27.89
fv_MarketCap=""
fv_VolatilityMonth=0.21 # if get String not Float because of trailing % in "0.21%" that's okay, will deal with it later
etc.
Я должен отметить, что я прекратил использовать любой тип CSV.read
или CSV.foreach
из-за ужасного замедления с использованием собственных объектов CSV Ruby 1.9.x , который считывался минутами и поэтому неприемлем приложение реального времени, которое запускается повторно.
Вместо этого я использовал канал Ruby для 'awk', чтобы назначать отдельные переменные, считываемые из файла мгновенно , например:
$stock="FCD"
$dividend_yield = IO.readlines("|awk -F, '$1==\"#{$stock}\" {print $9}' finviz.AllStocks.csv")[0].to_f
$beta = IO.readlines("|awk -F, '$1==\"#{$stock}\" {print $10}' AllStocks.csv")[0].to_f
но теперь становится слишком волосатым, чтобы не обобщать. Он должен работать с любым CSV-подобным файлом с неизвестными полями до первой строки, которую он видит.