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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

1295閲覧

RandomForestRegressor CSVモジュールで予測結果を1列で保存したい

xtail

総合スコア2

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

保存

保存(save)とは、特定のファイルを、ハードディスク等の外部記憶装置に記録する行為を指します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2021/10/07 06:17

前提・実現したいこと

RandomForestRegressorを用いてコンクリート強度の予測を行っています
そして予測結果をCSVモジュールを使って1列でCSVファイル保存をして、exelファイルに変換したいです。

しかし、予測結果が1行で出力されるので何か方法があれば教えていただきたいです。

該当のソースコード

"予測結果をCSVファイルに保存" import csv file = open('y_pred_RF1.csv','w', newline='') writer = csv.writer(file) writer.writerow(Y_pred) file.close()

試したこと

安直な考えでrow(行)をcolumn(列)に変えたりしましたが、案の定出来ませんでした。

補足情報(FW/ツールのバージョンなど)

python3.8 Spyder を使用しています。

###現状の出力
イメージ説明

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

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

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

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

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

guest

回答1

0

ベストアンサー

以下のようにreshapeによってn行x1列に変形し、writerowsで書き込めばよいです。
1行1列だけなので、あえてcsvモジュールを使う必要もありませんが。

Python

1from sklearn.ensemble import RandomForestRegressor 2import numpy as np 3 4# テストデータの作成 5# 決定木とランダムフォレスト 6# https://qiita.com/yshi12/items/6d30010b353b084b3749 7 8def sin_model(x, sigma=0.2): 9 """大きな波+小さな波+ノイズからなるダミーデータ。""" 10 noise = sigma * np.random.randn(len(x)) 11 return np.sin(5 * x) + np.sin(0.5 * x) + noise 12 13x = 10 * np.random.rand(100) 14y = sin_model(x) 15rfr = RandomForestRegressor(100) 16rfr.fit(x[:, None], y) 17xfit = np.linspace(0, 10, 10) 18Y_pred = rfr.predict(xfit[:, None]) 19 20 21"予測結果をCSVファイルに保存" 22import csv 23 24Y_pred = Y_pred.reshape(-1,1) # n行x1列に変形 25 26file = open('y_pred_RF1.csv','w', newline='') 27writer = csv.writer(file) 28writer.writerows(Y_pred) # ~row -> ~rows で複数行書込 29file.close()

投稿2021/10/07 06:45

can110

総合スコア38341

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

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

xtail

2021/10/20 03:27

解決しました!ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問