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

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

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

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

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

2回答

965閲覧

python pandas データフレームの列の結合方法

Shin_go

総合スコア19

Python

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

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

1グッド

0クリップ

投稿2021/09/16 02:56

イメージ説明

添付のようなデータフレームがあり、列の結合をしたいのですがどのようにしたらいでしょうか。

カーゴパンツ黒とカーゴパンツ紺

結合して
カーゴパンツ

とまとめてデータフレームを作りなおしたく思っています。
サイズ違いや色違いの同じ商品を人括りで売上管理をしたいという意図です。

よろしくお願いいたします。

ArMigELo👍を押しています

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

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

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

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

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

Daregada

2021/09/16 03:00

もっと小さな実験用のデータフレームを作成して質問中のコードブロックにCSVで提示、自分で書いてみた結合用のコードを質問中のコードブロックで提示、ぐらいはしてみましょう。
guest

回答2

0

ベストアンサー

kokyaku_yoyaku_shouhinが長いので、dfで説明します。

カーゴパンツ黒とカーゴパンツ紺を結合して

は(実際の列名は「カーゴパンツ・紺」と「カーゴパンツ・黑」なので)、df["カーゴパンツ・紺"] + df["カーゴパンツ・黑"]でSeriesを作成できます。

これを(末尾ではなく)「カーゴパンツ・紺」の位置に挿入し、「カーゴパンツ・紺」と「カーゴパンツ・黑」を削除するには、以下のようにします。

Python

1df = kokyaku_yoyaku_shouhin 2 3df.insert(df.columns.get_loc("カーゴパンツ・紺"), "カーゴパンツ", df["カーゴパンツ・紺"] + df["カーゴパンツ・黑"]) 4df.drop(columns=["カーゴパンツ・紺", "カーゴパンツ・黑"], inplace=True)

質問者がpd.pivot_tableで作成したデータフレームは、ブラウザーの画面をはみ出すほどの大きさなので、検証用に小さなデータフレームを作ります。実際のデータフレームでは、値が実数になっているので、こちらもそれを模倣します。

Python

1import pandas as pd 2import io 3 4 5txt = """ 6id,わかめ,カーゴパンツ・紺,カーゴパンツ・黑,りんご 71,1.0,0.0,0.0,9.0 82,0.0,2.0,0.0,0.0 93,5.0,0.0,1.0,1.0 104,1.0,1.0,2.0,1.0 11""" 12pd.set_option('display.unicode.east_asian_width', True) 13df = pd.read_csv(io.StringIO(txt), index_col="id") 14print(df) 15 16df.insert(df.columns.get_loc("カーゴパンツ・紺"), "カーゴパンツ", df["カーゴパンツ・紺"] + df["カーゴパンツ・黑"]) 17df.drop(columns=["カーゴパンツ・紺", "カーゴパンツ・黑"], inplace=True) 18print(df)

実行すると、元のデータフレームと加工後のデータフレームが出力されるので、「カーゴパンツ」列が想定通りの値になっているか確認します。

result

1 わかめ カーゴパンツ・紺 カーゴパンツ・黑 りんご 2id 31 1.0 0.0 0.0 9.0 42 0.0 2.0 0.0 0.0 53 5.0 0.0 1.0 1.0 64 1.0 1.0 2.0 1.0 7 わかめ カーゴパンツ りんご 8id 91 1.0 0.0 9.0 102 0.0 2.0 0.0 113 5.0 1.0 1.0 124 1.0 3.0 1.0

投稿2021/09/16 03:23

編集2021/09/16 03:59
Daregada

総合スコア11990

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

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

Shin_go

2021/09/16 03:28

回答ありがとうございます。これは、数値も足し算されて出力されるのでしょうか?
Daregada

2021/09/16 03:32

実際にやってみればわかりますよ。 データサイズが大きくて気軽にできないのであれば、それこそ「もっと小さな実験用のデータフレームを作成し、自分で書いた結合用のコードを実行」してみましょう。
Shin_go

2021/09/16 04:00

アドバイスありがとうございます。大変助かりました。
guest

0

kokyaku_yoyaku_shouhin["カーゴパンツ"] = kokyaku_yoyaku_shouhin["カーゴパンツ黒"] + kokyaku_yoyaku_shouhin["カーゴパンツ紺"] kokyaku_yoyaku_shouhin

これで1番右側に追加されませんか??

投稿2021/09/16 03:07

ArMigELo

総合スコア76

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

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

Shin_go

2021/09/16 04:00

ありがとうございます!こちらで実行できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問