🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

1回答

776閲覧

Pythonで文字列アンケートの結果を横持にしたい

TomokiSegawa

総合スコア13

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2020/01/07 00:02

編集2020/01/07 00:02

Pythonを、使って、アンケートの集計を行いたいと思っています。raw dataは、['回答ID', '質問', '回答']の3列からなっており、データ型は、回答IDはint, 他はすべてObjectです。
このデータを横持にしたいのですが、方法がわかりません…

どのようにcodingすればよいか、
知恵を貸していただけると助かります。

<現状>
回答ID 質問 回答
0001 質問1 aaaa
0001 質問2 bbbb
0001 質問3 cccc
0002 質問1 dddd
0002 質問2 eeee
0002 質問3 ffff

<やりたいこと>
回答ID 質問1 質問2 質問3
0001 aaaa bbbb cccc
0002 dddd eeee ffff

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

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

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

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

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

shiracamus

2020/01/07 00:43

Python標準機能だけを使ってですか? それとも numpy や pandas などの外部ライブラリを使ってもいいのですか?
TomokiSegawa

2020/01/07 01:26

pandasやnumpyを使って行いたいと思っています! raw dataはDataFrame形式で読み込んでおります。
guest

回答1

0

DataFrame.pivot() を使うと良いと思います

https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.DataFrame.pivot.html

Python

1import pandas as pd 2import io 3 4csv = """ 5回答ID,質問,回答 60001,質問1,aaaa 70001,質問2,bbbb 80001,質問3,cccc 90002,質問1,dddd 100002,質問2,eeee 110002,質問3,ffff 12""" 13 14df = pd.read_csv(io.StringIO(csv), dtype={'回答ID':str}) 15 16df = df.pivot(index='回答ID', columns='質問', values='回答') 17#質問 質問1 質問2 質問3 18#回答ID 19#0001 aaaa bbbb cccc 20#0002 dddd eeee ffff

投稿2020/01/07 00:29

編集2020/01/07 00:33
magichan

総合スコア15898

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問