similar in Bashを実行しましたが、Rubyの2-3行の簡略化された行でこれを行う方法がわかりませんが、正しいコーディングでKung -Fu。RubyのCSVヘッダー行から変数を作成する方法
私は次のようになりますヘッダー行と "file.csvになり" がありますように見える程度7000行が続き
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."
:ティッカーシンボル "FCD" を考える
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
を、私は、ヘッダーフィールドから取られた約30の新しい変数を「FCD」行に一致する値に大量に割り当てようとしています。
それぞれの新しい変数は接頭辞fv_
で、残りはフィールド名からすべての句読点、スペース、引用符などを除いて残ります(可変でないもの)。だから、
「FCDは、」私は私のスクリプトを与えることをしようとしているために:私は、原因horrible slowdown using native Ruby 1.9.x CSV objectsにCSV.read
またはCSV.foreach
のいずれかの種類を使用して終了読み取るために数分を要したため、受け入れられないことに注意してください
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.
繰り返し実行されるリアルタイムアプリケーションで実行されます。
$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
が、今では一般化しないように、あまりにも毛深いなっています:
代わりに、私は即座にこのようなファイルから読み込まれ、個々の変数を割り当てるには "awkのにRubyのパイプを使用してきました。未知のフィールドを持つCSVのようなファイルであれば、最初の行まで見る必要があります。
なぜ変数ですか?なぜ、{{"FCD" => someObject} 'のハッシュはありませんか? – Linuxios
ハッシュもうまくいかないかもしれませんが、高速である必要があります。 [以前の](http://stackoverflow.com/q/8476769/1069375)CSVをRubyに読み込むと失敗しました。 – Marcos
変数を使用してシンボルテーブルを満たすことは、ハッシュより効率的ではありません。また、何にでもグローバル変数を使用すると、特にこれは良い考えではありません。 – Linuxios