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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

DateTime

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

if

if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

Python

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

Q&A

解決済

2回答

1168閲覧

python 日付時刻の比較

swsjdeo

総合スコア1

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

DateTime

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

if

if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

Python

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

0グッド

0クリップ

投稿2021/03/12 02:30

編集2021/03/12 02:34

前提・実現したいこと

はじめて質問させていただきます。初心者です。
あるcsvから日付を持ってきて比較をしているのですが、上手くいきません。

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

date =2021/2/1 15:15:15

date.csv
2021/1/30 20:20:20
2021/1/30 22:22:22
2021/2/1 10:10:10
2021/2/1 15:15:15
2021/2/1 20:20:20
2021/2/2 10:10:10

2021/2/1 15:15:15からokと表示したいが、2021/2/1 10:10:10からok表示になる。

該当のソースコード

import csv

date =2021/2/1 15:15:15

with open('date.csv','r')as f:
____reader =csv.reader:
_____for row in reader:
________csvdata = row[0]

________pirnt(date)
________print(csvdate)

________if date <= csvdata:
__________print("ok")
________else:
__________print("ng")

インデントがうまくできなかったのでアンダーバーで代用しました。

試したこと

strftimeとstrptimeを使って日付型に変えて比較したりしましたが、やり方が悪いのか、上手くいきません。

補足情報(FW/ツールのバージョンなど)

環境 windwos10
python2.7.12

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

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

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

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

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

guest

回答2

0

ベストアンサー

strptimeを使って直ししてみました。
あと、インデントは<code>機能を使ってコードを囲うと見やすくなります。

python3

1import csv 2from datetime import datetime 3 4date = datetime.strptime("2021/2/1 15:15:15", "%Y/%m/%d %H:%M:%S") 5 6with open('date.csv','r')as f: 7 reader = csv.reader(f) 8 for row in reader: 9 csvdata = row[0] 10 csv_date = datetime.strptime(csvdata, "%Y/%m/%d %H:%M:%S") 11 print(csv_date) 12 if date <= csv_date: 13 print("ok") 14 else: 15 print("ng") 16# 2021-01-30 20:20:20 17# ng 18# 2021-01-30 22:22:22 19# ng 20# 2021-02-01 10:10:10 21# ng 22# 2021-02-01 15:15:15 23# ok 24# 2021-02-01 20:20:20 25# ok 26# 2021-02-02 10:10:10 27# ok

投稿2021/03/12 03:03

編集2021/03/12 03:04
jeanbiego

総合スコア3966

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

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

swsjdeo

2021/03/12 03:32

回答ありがとうございます。 なぜか、先ほどまでできなかったのですが、できるようになりました。ありがとうございます。
guest

0

文字列で比較しているからです。

datetimeに変換してから比較しましょう。
そのためには、pandasを使った方が良いでしょう。

python2はほどんど使われないので、python3にしましょう。

以下を見て勉強してみてはいかがですか。

pandasで日付・時間の列を処理(文字列変換、年月日抽出など)

投稿2021/03/12 02:48

ppaul

総合スコア24666

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

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

swsjdeo

2021/03/12 03:32

pandas使用してみます。ありがとうございます。 また諸事情がありpython2を使用しています。参考URLにて勉強します。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問