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

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

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

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

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

pandas

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

Q&A

解決済

1回答

5941閲覧

pandasまたはNumpyでエクセルのような表計算がしたい

ak_miyamoto

総合スコア31

NumPy

NumPyはPythonのプログラミング言語の科学的と数学的なコンピューティングに関する拡張モジュールです。

Python 3.x

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

pandas

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

0グッド

1クリップ

投稿2017/12/28 05:01

編集2017/12/28 05:05

環境:python3.6,win10

初学者です。以下のようなデータフレームに処理をしたいと考えております。具体的には、

sample

列1列2列3
91011
111213
131415

の各行の要素を、各行の合計値で除したいと考えています。
合計値は順に20,24,28ですから、以下のようなデータフレームを出力したいと考えております。なお、合計値もシリーズ
sum = (20,24,28)
となっております。

列1列2列3
9/2010/2011/20
11/2412/2413/24
13/2814/2815/28

pandasかNumpyで処理したいと考えております。よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

記述されている合計値が違う気がするのですが・・・

各列毎の合計値は (30,36,42)なのでは?

とりあえず pandas で行う場合、各行毎の合計値は
df.sum(axis=1)
にて得る事ができます。
その結果で各列毎に除算を行いますので
df.div(df.sum(axis=1), axis=0)
で処理できると思います。

一応確認するとこんな感じです

Python

1import pandas as pd 2 3df = pd.DataFrame([[9,10,11],[11,12,13],[13,14,15]]) 4print() 5ret = df.div(df.sum(axis=1), axis=0) 6print(ret) 7# 0 1 2 8# 0 0.300000 0.333333 0.366667 9# 1 0.305556 0.333333 0.361111 10# 2 0.309524 0.333333 0.357143

投稿2017/12/28 05:51

magichan

総合スコア15898

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

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

ak_miyamoto

2017/12/28 06:07

うまくいきました!之で作業を進めることができます、ありがとうございます。 PS合計値の件おっしゃる通りです。失礼いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問