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

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

ただいまの
回答率

90.35%

  • Python

    9138questions

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

  • Raspberry Pi

    891questions

    Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。

pythonでcsvを取得したい

解決済

回答 3

投稿

  • 評価
  • クリップ 0
  • VIEW 197

morutemu

score 33

pythonでcsvをリスト形式で取得し、そこから「日付」をキーにして検索し、「状況」を取得するようなものを作りたいのですが、リスト形式をどのように検索できるようにしたらよいかかわからず困っております。

csv_file.csv

日付 曜日 状況
2018/4/1
2018/4/2 ×
2018/4/3

ソースコード

#!/usr/bin/env python
# -*- coding: utf-8 -*-

# +++ モジュール +++
import csv

# csv読み込み処理
def read_csv(self):
    # 変数
    list_data = []

    # csvファイル読み込み
    with open("./csv_file.csv", "r", encoding="ms932", errors="", newline="" ) as f:
        # csv読み込み
        reader = csv.reader(f)

        # csvのヘッダー(一行目)を読み飛ばす
        header = next(reader)

        # csvファイルをリスト形式で保存
        for row in reader:
            list_data.append(row)

        # リストデータを返す
        return list_data

# メイン処理
def main(self):
    today_is = "2018/4/2"
    # csvの読み込み
    list_data = read_csv()

    # ここから検索させたい…

# +++ 初期動作 +++
if __name__ == "__main__":
    main()

リストを辞書形式にしないとだめなのでしょうか??
どうか教えてください。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

checkベストアンサー

+3

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/24 10:04

    すみません、ちなみに
    def read_csv(self):
    # csvファイルを読み込む
    gbd_df = pd.read_csv("./csv_file.csv" ,encoding='cp932')
    print(gbd_df.query('日付 == "2018/4/24"'))

    このような形で検索出来たのですが、状況のデータを取り出すにはどうしたら良いでしょうか??

    キャンセル

  • 2018/04/24 13:14 編集

    このように扱えます。
    >>> import pandas as pd
    >>> df = pd.DataFrame([[1,2,3],[4,5,6],[7,8,9]], columns=["hoge","fuga","piyo"])
    >>> df
    hoge fuga piyo
    0 1 2 3
    1 4 5 6
    2 7 8 9
    >>> df.query("hoge == 1")
    hoge fuga piyo
    0 1 2 3
    >>> df.query("hoge == 1")["piyo"]
    0 3

    キャンセル

  • 2018/04/24 19:05

    >>> df.query("hoge == 1")["piyo"]
    0 3
    すみません、こちらを3のみ取得したい場合はどうしたらよいでしょうか?
    strなどで。。
    後で、if文などに使いたいと思いまして。

    キャンセル

  • 2018/04/24 19:09

    df.query("hoge == 1")["piyo"].values[0]でいけます

    キャンセル

  • 2018/04/24 20:17

    おおおおお!ありがとうございます!
    いけました!!
    ありがとうございました。

    キャンセル

  • 2018/04/24 20:24

    参考情報ですが、df.queryは遅いらしいので、こう書いた方が得します
    df[df["hoge"] == 1]["piyo"].values[0]

    参考:
    https://funmatu.wordpress.com/2017/06/11/df-query%E3%82%88%E3%82%8A%E6%99%AE%E9%80%9A%E3%81%AB%E6%9B%B8%E3%81%8F%E6%96%B9%E3%81%8C%E5%A4%9A%E5%88%86%E8%89%AF%E3%81%84/

    キャンセル

  • 2018/04/24 20:57

    おおっ!ありがとうござます!
    書き換えます!

    キャンセル

+1

 self不要

  • def read_csv(self): などの関数定義の第1引数に self を書いていますが不要です。
  • おそらく、クラスのメソッドに書かれている物を真似しようと思ったのかと思いますがこのコードの中では不要です。(今実行してもエラーになるでしょう。

 実行して小さく考えてみよう

  • read_csv()の結果は何になっていますか? 予定通りの結果でしょうか?
  • 狙い通りになっている可能性もありますし、狙いと違うかもしれません。それを踏まえて次の事を考えましょう。

 検索したい

  • どうなれば検索できるたといえるのでしょうか?
  • dictのキーに日付を入れておいたとして、結果はどのような形式が良いのでしょうか?

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/23 17:16

    そうですねぇ、イメージとしては、
    raspberry piを付けっぱなしにして、毎日今日の日付を取得し、その日付からcsvの「日付」をさがして「状況」の値を取得するようなものができると嬉しいです。

    キャンセル

-1

参考情報

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Python

    9138questions

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

  • Raspberry Pi

    891questions

    Raspberry Piは、ラズベリーパイ財団が開発した、名刺サイズのLinuxコンピュータです。 学校で基本的なコンピュータ科学の教育を促進することを意図しています。