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

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

詳細はこちら
DateTime

多くのプログラミング言語におけるDateTimeオブジェクトは、日付と時間に関する演算と出力を行います。

NumPy

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

Python

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

pandas

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

Q&A

解決済

2回答

3811閲覧

Pandas 時系列データで特定の日付のみ抽出したい

退会済みユーザー

退会済みユーザー

総合スコア0

DateTime

多くのプログラミング言語におけるDateTimeオブジェクトは、日付と時間に関する演算と出力を行います。

NumPy

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

Python

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

pandas

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

0グッド

0クリップ

投稿2019/12/22 02:51

下記の様な時系列データがあるのですが、
特定の日付(2010-01-01など)を、抽出しようとするとKeyErrorが発生します。
(ちなみにスライスを使ってdata2['2010-01-01':]はエラーとなりません。)

すごい簡単そうなことですが、何が問題なのかいまいちわかりません。
(データの作り方なのか文法的に間違っているのか)
どなたか解決方法お分かりになりますでしょうか?

日付 温度
2010-01-01 10
2010-01-04 11
2010-10-11 18

python

1import numpy as np 2import pandas as pd 3 4vec2 = np.array([ [10,'2010-01-01'] , [11,'2010-01-04'],[18,'2010-10-11'] ]) 5 6data2 = pd.DataFrame(vec2,columns=['温度','日付']) 7data2['日付']=pd.to_datetime(data2['日付']) 8data2.set_index('日付',inplace=True) 9 10data2['2010-01-01']

KeyError: '2010-01-01'

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

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

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

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

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

guest

回答2

0

data2.loc['2010-01-01']
もしくは
data2.loc[pd.to_datetime('2010-01-01')]
です。

.locがないとカラム名を探しに行きます。

投稿2019/12/22 06:34

bsdfan

総合スコア4794

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

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

退会済みユーザー

退会済みユーザー

2019/12/22 09:33

なるほど!そういうやり方もあるのですね。ありがとうございます。
guest

0

ベストアンサー

data2[data2.日付=='2010-01-01']
みたいな感じでいけると思います。

(追記)
うまくいかないのは日付をindexにしているからです。
indexについて
set_indexは外しましょう。
特定行の抽出

投稿2019/12/22 03:05

編集2019/12/22 03:11
gnbrganchan

総合スコア438

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

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

退会済みユーザー

退会済みユーザー

2019/12/22 09:30

indexにしているか否かの違いなんですね。。。意識していないとなぜなぜってなってしまいますね。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問