日付処理に関しては、Python では標準ライブラリ datetime、サードパーティ ライブラリ dateutil、arrow など、多くのライブラリが提供されています。
使用する前にインストールする必要があります。pip install pendulum を実行するだけです。
使い方を見てみましょう、最初は日時、日付、時刻の作成です。
import pendulum dt = pendulum.datetime( 2022, 3, 28, 20, 10, 30) print(dt.__class__) print(dt) """ <class 'pendulum.datetime.DateTime'> 2022-03-28T20:10:30+00:00 """ # 创建的对象是 DateTime 类型 # 并且带有时区,默认是 UTC # 我们可以换一个时区 dt = pendulum.datetime( 2022, 3, 28, 20, 10, 30, tz="Asia/Shanghai") print(dt) """ 2022-03-28T20:10:30+08:00 """ # 如果不想要时区,那么指定 tz=None dt = pendulum.datetime( 2022, 3, 28, 20, 10, 30, tz=None) print(dt) """ 2022-03-28T20:10:30 """ # 然后是 date 的创建 d = pendulum.date(2022, 3, 28) print(d.__class__) print(d) """ <class 'pendulum.date.Date'> 2022-03-28 """ # time 的创建 t = pendulum.time(20, 10, 30) print(t.__class__) print(t) """ <class 'pendulum.time.Time'> 20:10:30 """
日時を作成すると、タイムゾーンはデフォルトで UTC になります。タイム ゾーンを使用しない場合、またはタイム ゾーンをローカル タイム ゾーンにしたい場合、Pendulum には 2 つの方法も用意されています。
import pendulum # 创建 datetime 时设置为本地时区 # 还是调用了 pendulum.datetime 函数 # 但是 tz 被设置成了 pendulum.local_timezone() dt = pendulum.local( 2022, 3, 28, 20, 10, 30) print(dt) """ 2022-03-28T20:10:30+08:00 """ print(pendulum.local_timezone()) """ Timezone('Asia/Shanghai') """ # 创建 datetime 时不设置时区 # 内部也是调用了 pendulum.datetime 函数 # 但是 tz 为 None dt = pendulum.naive(2022, 3, 28, 20, 10, 30) print(dt) """ 2022-03-28T20:10:30 """
その後、pendulum には、現在の日時や日付などの作成など、いくつかのメソッドも用意されています。
import pendulum # 创建当前的 datetime # 默认是本地时区,但时区可以指定 dt = pendulum.now() print(dt) """ 2022-05-29T20:40:49.632182+08:00 """ # 创建当前的 date,但返回的仍是 datetime # 只不过时分秒均为 0,同样可以指定时区 dt = pendulum.today() print(dt) """ 2022-05-29T00:00:00+08:00 """ # 获取明天对应的 date # 返回的是 datetime,时分秒为 0 # 时区可以指定,默认是本地时区 dt = pendulum.tomorrow() print(dt) """ 2022-05-30T00:00:00+08:00 """ # 获取昨天对应的 date dt = pendulum.yesterday() print(dt) """ 2022-05-28T00:00:00+08:00 """
タイムスタンプや文字列に基づいて作成することもできます:
import pendulum # 根据时间戳创建 dt1 = pendulum.from_timestamp(1653828466) dt2 = pendulum.from_timestamp(1653828466, tz=pendulum.local_timezone()) print(dt1) print(dt2) """ 2022-05-29T12:47:46+00:00 2022-05-29T20:47:46+08:00 """ # 根据字符串创建 dt1 = pendulum.parse("2020-05-03 12:11:33") dt2 = pendulum.parse("2020-05-03 12:11:33", tz=pendulum.local_timezone()) print(dt1) print(dt2) """ 2020-05-03T12:11:33+00:00 2020-05-03T12:11:33+08:00 """
日時、日付、時刻の作成についての説明は終わりました。次に、それらがサポートする操作を見てみましょう。 、これも核心部分です。
たくさんの操作がありますので、一つずつ紹介していきます。
import pendulum dt = pendulum.local( 2022, 3, 28, 20, 10, 30) # 获取 date 部分和 time 部分 print(dt.date()) print(dt.time()) """ 2022-03-28 20:10:30 """ # 替换掉 dt 的某部分,返回新的 datetime # 年月日时分秒、以及时区都可以替换 print(dt.replace(year=9999)) """ 9999-03-28T20:10:30+08:00 """ # 转成时间戳 print(dt.timestamp()) """ 1648469430.0 """ # 返回年、月、日、时、分、秒、时区 print(dt.year, dt.month, dt.day) print(dt.hour, dt.minute, dt.second) print(dt.tz) """ 2022 3 28 20 10 30 Timezone('Asia/Shanghai') """
その後、文字列が生成されます。pendulum.DateTime オブジェクトは、さまざまな形式の日付文字列に変換できます。
import pendulum dt = pendulum.local( 2022, 3, 28, 20, 10, 30) # 下面四个最为常用 print("datetime:", dt.to_datetime_string()) print("date:", dt.to_date_string()) print("time:", dt.to_time_string()) print("iso8601:", dt.to_iso8601_string()) """ datetime: 2022-03-28 20:10:30 date: 2022-03-28 time: 20:10:30 iso8601: 2022-03-28T20:10:30+08:00 """ # 当然还支持很多其它格式,不过用的不多 # 随便挑几个吧 print("atom:", dt.to_atom_string()) print("rss:", dt.to_rss_string()) print("w3c:", dt.to_w3c_string()) print("cookie:", dt.to_cookie_string()) print("rfc822:", dt.to_rfc822_string()) """ atom: 2022-03-28T20:10:30+08:00 rss: Mon, 28 Mar 2022 20:10:30 +0800 w3c: 2022-03-28T20:10:30+08:00 rfc822: Mon, 28 Mar 22 20:10:30 +0800 """
現在の日付が何曜日であるか、今年の何日であるかなどを判断する必要がある場合もあります。Pendulum はそれもパッケージ化しています。
import pendulum dt = pendulum.local( 2022, 3, 28, 20, 10, 30) # 返回星期几 # 注意:星期一到星期天分别对应 1 到 7 print(dt.isoweekday())# 1 # 返回一年当中的第几天 # 范围是 1 到 366 print(dt.day_of_year)# 87 # 返回一个月当中的第几天 print(dt.days_in_month)# 31 # 返回一个月当中的第几周 print(dt.week_of_month)# 5 # 返回一年当中的第几周 print(dt.week_of_year)# 13 # 是否是闰年 print(dt.is_leap_year())# False
最後は振り子の最も強力な部分である日付演算ですが、なぜこれが強力なのかについては、実際にデモしてみると分かります。
import pendulum dt = pendulum.local( 2022, 3, 30, 20, 10, 30) # 返回下一个月的今天 print(dt.add(months=1)) """ 2022-04-30T20:10:30+08:00 """ # 返回上一个月的今天 # 但是上一个月是 2 月,并且是平年 # 所以最多 28 天 print(dt.add(months=-1)) """ 2022-02-28T20:10:30+08:00 """ # 我们看到处理的非常完美 # 该方法的原型如下,年月日时分秒都是支持的,当然还有星期也支持 """ def add( self, years=0, months=0, weeks=0, days=0, hours=0, minutes=0, seconds=0, microseconds=0, ): """
Python の組み込みモジュール datetime と同様に、日付を追加する場合は日までサポートされますが、翌週、来月、来年の日付を計算することはできません。一方、ペンデュラムは扱いが簡単で、そこが私が最も気に入っている点です。
もちろん、add の値が正の場合は日付を後方に移動することと同等であり、値が負の場合は日付を前方に進めることと同等です。
その後、2 つの日付を減算することもできます:
import pendulum dt1 = pendulum.local( 2021, 1, 20, 11, 22, 33) dt2 = pendulum.local( 2022, 3, 30, 20, 10, 30) period = dt2 - dt1 # 返回的是 Period 对象 # 相当于 datetime 模块里面的 timedelta print(period.__class__) """ <class 'pendulum.period.Period'> """ # 但是功能方面,Period 要强大很多 # 两者差了多少年 print(period.in_years())# 1 # 两者差了多少个月 print(period.in_months())# 14 # 两者差了多少个星期 print(period.in_weeks())# 62 # 两者差了多少天 print(period.in_days())# 434 # 两者差了多少个小时 print(period.in_hours())# 10424 # 两者差了多少分钟 print(period.in_minutes())# 625487 # 两者差了多少秒 print(period.in_seconds())# 37529277
この関数は非常に強力です。Python の datetime モジュールの timedelta は、最大でも 2 つの日付の差の日数しか計算できません。年と月 日、時、分、秒が表示されます。
以上がこの記事の内容です。もちろん振り子の機能は上記以外にもたくさんあります。興味のある方は公式サイトを参照してください。一般的なのはこれらです。中古のもの。
以上がPython 日付ライブラリ振り子を使用して日付と時刻を処理するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。