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

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

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

openpyxlは、Excel2007以降のファイル(xlsx/xlsm/xltx/xltm)を読み書きするためのPythonライブラリです。

Python 3.x

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

Python

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

pandas

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

PyCharm

エディター・開発ツール

Q&A

0回答

958閲覧

[Python3]Excel表のデータを種類ごとに分けて時系列順に並べ,一番最近のデータを表示したい

MM921

総合スコア14

openpyxl

openpyxlは、Excel2007以降のファイル(xlsx/xlsm/xltx/xltm)を読み書きするためのPythonライブラリです。

Python 3.x

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

Python

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

pandas

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

PyCharm

エディター・開発ツール

0グッド

0クリップ

投稿2021/02/08 05:37

編集2021/02/08 05:44

前提・実現したいこと

python3.8でExcelの出庫履歴表からひと月で備品が種類ごとに合計何個になっているかを表す月末決算表を作ろうとしています。

現在データを備品ごとに分けた状態でその中での最小値を取り出しています。
しかしよくよく考えてみると備品が途中入荷されることも考えられるため種類ごとに分けたデータ中の最小だとつじつまが合わなくなるケースが出てくることに気が付きました。(うかつでした。)

上記を種類ごとに分けたデータを時系列ごとにまとめてその中で最新のデータを取り出して月末決算.xlsxに記入する形で改良したいと思っております。

python初心者のため,お力を貸していただければ幸いです。
↓出庫履歴の表.xlsx

備品名備品個数消費個数日付
lll30002021/02/04
iii29912021/02/04
ggg29912021/02/04
ggg29912021/02/04
fff25522021/02/03
eee25122021/02/03
ddd25112021/02/03
bbb22512021/02/03
fff25712021/02/03
eee25322021/02/03
ccc21722021/02/03
aaa14112021/02/03

発生している問題・エラーメッセージ

上記にもあるように,最新のデータではなく最小の値を取り出している状態なため追加入荷等があれば入荷後の備品個数がわからなくなってしまいます。
なので以下のコードを試してみたところ,sum()がついているため合計してしまいます。

import pandas as pd import openpyxl as px df = pd.read_excel('出庫履歴の表.xlsx', sheet_name='Sheet1') Aall = df[df['備品名'].values == 'aaa'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Ball = df[df['備品名'].values == 'bbb'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Call = df[df['備品名'].values == 'ccc'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Dall = df[df['備品名'].values == 'ddd'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Eall = df[df['備品名'].values == 'eee'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Fall = df[df['備品名'].values == 'fff'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Gall = df[df['備品名'].values == 'ggg'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Hall = df[df['備品名'].values == 'hhh'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Iall = df[df['備品名'].values == 'iii'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Jall = df[df['備品名'].values == 'jjj'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Kall = df[df['備品名'].values == 'kkk'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Lall = df[df['備品名'].values == 'lll'].groupby(['日付']).sum().drop(['消費個数'], axis=1) Mall = df[df['備品名'].values == 'mmm'].groupby(['日付']).sum().drop(['消費個数'], axis=1) print(Aall) print(Ball) print(Call) print(Dall) print(Eall) print(Fall) print(Gall) print(Hall) print(Iall) print(Jall) print(Kall) print(Lall) print(Mall)
備品個数 日付 2021/02/03 141 備品個数 日付 2021/02/03 225 備品個数 日付 2021/02/03 217 備品個数 日付 2021/02/03 251 備品個数 日付 2021/02/03 504 備品個数 日付 2021/02/03 512 備品個数 日付 2021/02/04 598 Empty DataFrame Columns: [備品個数] Index: [] 備品個数 日付 2021/02/04 299 Empty DataFrame Columns: [備品個数] Index: [] Empty DataFrame Columns: [備品個数] Index: [] 備品個数 日付 2021/02/04 300 Empty DataFrame Columns: [備品個数] Index: []

sum()を外すと以下のようなエラーメッセージが出てきました。

raise AttributeError( AttributeError: 'DataFrameGroupBy' object has no attribute 'drop'

お時間あればお力添えいただければと思います。

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

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

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

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

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

ppaul

2021/02/08 05:50

入庫個数の情報を入れていないことが問題なのではないでしょうか。
MM921

2021/02/08 23:48

ppaulさん,ご回答ありがとうございます。返信が遅れて申し訳ありません。 入庫個数はaaa.txtやbbb.txtなどのテキストに個数を入力しているものをtkinterlabelで表示させている形ですので入庫したい数だけテキストに書かれている個数にプラスする方法で入庫情報を入れようと思っています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問