質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

1250閲覧

undefined method `/' for [2, 20001]:Arraynita

ganbarou_nippon

総合スコア18

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/02/10 07:43

ruby

1undefined method `/' for [2, 20001]:Array 2 3@profit_changes << profit_month/@user.notes.sum(:profit_and_loss)*100

下の部分で上のようなエラーが起きています。

これはなぜなのでしょうか?

データが存在しない場合は分岐で避けているはずなのですが…割り算が使えないです。。

以下はindexアクション全てのコードです。

対策がわかる方ご教授の方よろしくお願い申し上げます。

ruby

1class UsersController < ApplicationController 2 3 def index 4 @user=current_user 5 @notes=@user.notes.all.order("id DESC").page(params[:page]).per(30) 6 @comments=[] 7 if @user.notes.present? 8 @notes.each do |note| 9 @comments << note.comments.count 10 end 11 end 12 @profit_symbol=@user.notes.group(:symbol).sum(:profit_and_loss) 13 profit_month=@user.notes.group("MONTH(created_at)") 14 @profit_changes=[] 15 if @user.notes.present? 16 profit_month.sum(:profit_and_loss).each do |profit_month| 17 @profit_changes << profit_month/@user.notes.sum(:profit_and_loss)*100 18 end 19 end 20 @profit_changes_symbol=[] 21 if @user.notes.present? 22 @user.notes.group(:symbol,"MONTH(created_at)").each do |profit_changes_symbol| 23 @profit_changes_symbol << (profit_changes_symbol.sum(:profit_and_loss)/@profit_symbol*100) 24 end 25 end 26 @victory_rates=[] 27 if @user.notes.present? 28 @user.notes.where(:profit_and_loss > 0).group("MONTH(created_at)").each do |victory_rates| 29 @victory_rates << (victory_rates.count/profit_month.count) 30 end 31 end 32 this_month = Date.today.all_month 33 before_month=Date.today.last_month 34 profit_this_month = [] 35 profit_before_month = [] 36 @user.notes.each do |note| 37 if this_month.include?(Date.parse(note[:created_at].to_s)) 38 profit_this_month << note 39 elsif before_month.include?(Date.parse(note[:created_at].to_s)) 40 profit_before_month << note 41 end 42 end 43 @profit_this_month= profit_this_month.sum(:profit_and_loss) 44 if @user.notes.present? 45 @profit_this_month_average = @profit_this_month / profit_this_month.length 46 @victory_rate_this_month = profit_this_month.where(:profit_and_loss > 0).count/profit_this_month.count 47 end 48 @profit_before_month= profit_before_month.sum(:profit_and_loss) 49 if @user.notes.present? 50 @profit_before_month_average= @profit_before_month.to_i / profit_before_month.length 51 @victory_rate_before_month=profit_before_month.where(:profit_and_loss > 0).count/profit_before_month.count 52 end 53 end

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

これはなぜなのでしょうか?

エラーメッセージのとおりです。profit_monthの値が配列なので、そのままでは計算できません。

投稿2020/02/10 07:54

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ganbarou_nippon

2020/02/10 07:58

配列なのでそれをeachメソッドで一つずつ取り出して、上で宣言した殻の配列に入れているはずなのですが…それでも計算できませんか?
maisumakun

2020/02/10 08:05

> 配列なのでそれをeachメソッドで一つずつ取り出して、上で宣言した殻の配列に入れているはずなのですが そうなっていないからエラーになっています。
taichi730

2020/02/10 10:16

`profit_month.sum(:profit_and_loss).each` が意図した記述でないと予想
ganbarou_nippon

2020/02/11 03:14

'''profit_month.sum(:profit_and_loss).each do |profit_month| @profit_changes << profit_month/@user.notes.sum(:profit_and_loss)*100 end''' この部分が配列になっていないということですよね?? 上で月ごとにグループ化したものを'''profit_month'''という変数に入れて、そして月ごとに出した'''(:profit_and_loss)'''の合計を全ての合計で割って、その月ごとの値を'''@profit_changes'''に入れたいのですがどうすれば良いでしょうか??
maisumakun

2020/02/11 03:58

> この部分が配列になっていないということですよね?? そうですね、group化したものにsumをかけているので、キーが月のハッシュで来ているかと思います。
ganbarou_nippon

2020/02/11 04:46 編集

なるほど。。。承知しました!教えていただきありがとうございます。 もう一つ質問があるのですが、 '''@user.notes.group(:symbol,"MONTH(created_at)").sum(:profit_and_loss).values.each do |profit_changes_symbol|''' のように二つの要素でグループ化している場合、:symbolごとに月単位(MONTH(created_at))の値に対して """@profit_changes_symbol << profit_changes_symbol/@profit_symbol*100"""" という処理を行いたいです。 その際にHash can't be coerced into Integerというエラーが出てしまうのですが、どうすれば良いでしょうか? この時、:symbol、と"MONTH(created_at)"のインデックスをkeysで別々に取得して、それぞれを別の配列に入れたいのですがどうすれば良いでしょうか?? 何度もすみません。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問