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

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

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

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 2.7

Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

Python 3.x

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

Python

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

pandas

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

Q&A

解決済

2回答

242閲覧

Pythonで変数に値を入れるときのケース文

Ponta2929

総合スコア16

Jupyter

Jupyter (旧IPython notebook)は、Notebook形式でドキュメント作成し、プログラムの記述・実行、その実行結果を記録するツールです。メモの作成や保存、共有、確認などもブラウザ上で行うことができます。

Python 2.7

Python 2.7は2.xシリーズでは最後のメジャーバージョンです。Python3.1にある機能の多くが含まれています。

Python 3.x

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

Python

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

pandas

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

0グッド

0クリップ

投稿2020/03/02 08:45

Pythonでカラムのデータの値に応じて別の新しいカラムに別の値を入れるためにはどうすれば良いのでしょうか?

イメージとしてはSQLのCASE文です。

たとえば
teamというデータの個人を特定するユニークなキー「name_key」が入っているとします。
別のカラムにはその人が購入した商品「item」のカラムがあります。

「name_key」の値を参照して値に応じて、別のカラム「name」に買った人の名前を入れたいです。
以下が値に応じた名前の対応表です。

a > '太郎'
b > '花子'
c > '翔太'
d > '隆'
e > '綾'

出したいデータのアウトプットイメージは以下です。

出したいデータのイメージ

お願いします。

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

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

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

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

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

guest

回答2

0

ベストアンサー

dict型 または Series型の変換テーブルを準備して

  • Series.map() にて変換テーブルを引き当てる
  • Series.replace()にて変換テーブルで変換をかける

どちらかを行うと良いかと思います。

https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.Series.map.html

https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.Series.replace.html

Python

1import pandas as pd 2 3df = pd.DataFrame({ 4 'item':['カバン','服','服','食べ物'], 5 'name_key':['a','b','d','c']}) 6 7conv = {'a':'太郎', 'b':'花子', 'c':'翔太', 'd':'隆' } 8 9df['name1'] = df['name_key'].map(conv) 10 11df['name2'] = df['name_key'].replace(conv) 12 13print(df) 14# item name_key name1 name2 15#0 カバン a 太郎 太郎 16#1 服 b 花子 花子 17#2 服 d 隆 隆 18#3 食べ物 c 翔太 翔太

今回の場合は、両方ともに同じ結果がえられます。

前者と後者の違いは、変換テーブル無い場合の処理で、前者が NaN になるのに対して、後者は変換しないという動作になります。

投稿2020/03/02 09:27

magichan

総合スコア15898

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

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

0

対応表が辞書(dict)で与えられているとすると、以下のように.applyでできます。

Python

1import pandas as pd 2 3df = pd.DataFrame({'key':['a','b','c','d'],'value':[1,2,3,4]}) 4 5names = {'a':'taro', 'b':'hanako', 'c':'syota'} # 対応表 6df['name'] = df['key'].apply( lambda k : names.get(k,'?')) 7print(df) 8# key value name 9#0 a 1 taro 10#1 b 2 hanako 11#2 c 3 syota 12#3 d 4 ?

投稿2020/03/02 08:59

can110

総合スコア38341

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問