へっぽこプログラマーの備忘録
プログラムを中心とした個人的なメモ用のブログです。 タイトルは迷走中。
内容の保証はできませんのであしからずご了承ください。
menu
keyboard_arrow_up
Top
search
close
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
home
ホーム
computer
PC一般
construction
開発環境・ツール
code
プログラミング
Home
›
Python
›
[Python] datetime とタイムゾーンについてのメモ
2021/09/13
[Python] datetime とタイムゾーンについてのメモ
update
event_note
label
Python
ちょっとはまったのでメモしておきます。
## 環境 - python 3.8.10 ## navive と aware まず、`datetime` 型にはタイムゾーンの情報を持たない `naive` と、タイムゾーンの情報を持つ `aware` な datetime 型があるようです。 ### naive な datetime 型 ```py from datetime import datetime, date, timedelta, timezone dt = datetime.now() print(dt.isoformat()) ``` **出力結果** ``` 2021-09-13T15:11:50.968159 ``` ### aware な datetime 型 ```py from datetime import datetime, date, timedelta, timezone JST = timezone(timedelta(hours=+9), 'JST') dt = datetime.now(JST) print(dt.isoformat()) ``` **出力結果** `datetime.now` で `JST` を指定しているので、文字列で出力したときに `+09:00` が付与されています。 ``` 2021-09-13T15:12:28.720290+09:00 ``` ## 文字列から datetime への変換 ```py str = '2021-09-13T15:11:50.968159' dt = datetime.fromisoformat(str) print(dt) str = '2021-09-13T15:12:28.720290+09:00' dt = datetime.fromisoformat(str) print(dt) ``` **出力結果** 文字列にタイムゾーンに関する情報がなければ `naive`、あれば `aware` な `datetime` 型になっていることがわかります。 ``` 2021-09-13 15:11:50.968159 2021-09-13 15:12:28.720290+09:00 ``` ## naive から aware への変換 `naive` に対して `astimezone` でタイムゾーンの情報を付与すると `aware` になります。 ```py str = '2021-09-13T15:11:50.968159' dt = datetime.fromisoformat(str) # naive print(dt) jst_dt = dt.replace(tzinfo=timezone.utc) # aware print(jst_dt) ``` ``` 2021-09-13 15:11:50.968159 2021-09-13 15:11:50.968159+00:00 ``` ## UTC から JST への変換 ```py str = '2021-09-13T15:11:50.968159' # タイムゾーンの情報がないので、naive な datetime になる dt = datetime.fromisoformat(str) # naive print(dt) # 上記の dt は UTC として解釈する(タイムゾーンを付与する) utc = dt.replace(tzinfo=timezone.utc) # aware(UTC) print(utc) # JST に変換する jst = utc.astimezone(JST) # aware(JST) print(jst) ``` **出力結果** ``` 2021-09-13 15:11:50.968159 2021-09-13 15:11:50.968159+00:00 2021-09-14 00:11:50.968159+09:00 ``` ## タイムゾーンのない文字列を JST として読み込む 上記の応用で、最初から JST を指定してやると OK です。 ```py str = '2021-09-13T15:11:50.968159' # タイムゾーンの情報がないので、naive な datetime になる dt = datetime.fromisoformat(str) # naive print(dt) # 上記の dt は JST として解釈する(タイムゾーンを付与する) JST = timezone(timedelta(hours=+9), 'JST') jst = dt.replace(tzinfo=JST) # aware(JST) print(jst) ``` **出力結果** ``` 2021-09-13 15:11:50.968159 2021-09-13 15:11:50.968159+09:00 ```
## 参考 URL - https://docs.python.org/ja/3/library/datetime.html - https://zenn.dev/toriwasa/articles/0b842ec4a3cb65 - https://qiita.com/shota243/items/91660ece72b5e84c3adb
tweet
facebook
Pocket
B!
はてブ
LINE
chevron_left
chevron_right
Translate
Popular Posts
TortoiseGit でコミットメッセージを変更する
image
NO IMAGE
smbclient で session setup failed: NT_STATUS_LOGON_FAILURE が表示される
Docker for Windows の設定
image
NO IMAGE
TortoiseSVN ロック状態のチェック
image
NO IMAGE
マージ元ブランチとマージ先ブランチ
image
NO IMAGE
Visual Studio で文字がにじむ(ぼやける)
TortoiseGit でブランチ間の差分を見る
image
NO IMAGE
AsciidocFX をビルドする
image
NO IMAGE
PowerShellでブレークポイントが設定できない場合
[Python] 文字列の判定で、None と空文字を同時に判定する
Labels
.NET Core
31
.NET Framework
17
.NET Standard
2
AdminLTE
1
AI
1
Apache
3
AppVeyor
2
AsciiDoc
7
ASP.NET Core
55
Atom
4
AWS
5
AWS Cloud9
4
blockdiag
1
Blogger
13
Bootstrap
3
C/C++
6
C#
106
CentOS
3
Chrome
1
Chronograf
3
chrony
1
Codecov
1
CSS
1
Docker
82
DokuWiki
4
Doxygen
1
draw.io
1
EasyTag
1
Electron
1
Electron.NET
2
Entity Framework Core
9
Excel
2
FFmpeg
3
Firefox
6
Flask
1
Git
19
GitBook
4
GitBucket
7
GitHub
7
GitLab
39
Go
1
Google
1
Google Cloud Platform
1
Grafana
13
GStreamer
2
HTML
5
IIS
8
InfluxDB
14
JavaScript
15
Jekyll
3
Jenkins
7
Linux
34
Log4View
1
MahApps.Metro
3
MaterialDesignInXamlToolkit
1
MkDocs
2
MongoDB
5
MVC
1
MVVM
6
nginx
3
NLog
3
Node.js
8
npm
1
NVIDIA
3
onvif
1
OpenAPI
2
OpenCV
4
OpenSSL
3
OpenVINO
2
ownCloud
2
pandas
1
Pine Script
1
PlantUML
5
Portainer
3
PowerShell
8
Prism
2
PySide
19
Python
88
PyTorch
1
RabbitVCS
1
Razor
3
redis
1
Redmine
33
Redoc
1
remark.js
2
rocketchat
10
Ruby
3
scikit-learn
1
shotcut
1
SignalR
1
Slack
1
Socket.IO
1
SonarQube
5
Sphinx
10
SQL Server
5
SQLite
1
StableDiffusion
2
Subversion
2
Swagger
1
Swarmpit
1
Syslog
3
Telegraf
6
Tesseract
3
TestLink
2
Tomcat
2
TortoiseGit
11
TortoiseSVN
2
Trading View
1
Traefik
3
Travis CI
1
Ubuntu
31
Visual Studio
39
Visual Studio Code
10
VSCode
8
Vue.js
8
Windows
62
Windows 10
5
Windows ADK
1
Windows API
2
Windows Embedded
4
wkhtmltopdf
2
Word
3
WPF
12
WSL
5
WSL2
5
Xamarin
1
xUnit
5
yaml
1
yolo
1
アプリケーション
1
デザインパターン
1
テスト
1
バッチファイル
2
プログラミング
4
ライセンス
1
暗号資産(仮想通貨)
1
英語
2
確定申告
1
機械学習
1
強化学習
1
雑記
1
書籍
1
数学
1
正規表現
1
動画編集
1
Blog Archive
►
2024
(21)
►
12月
(3)
►
9月
(5)
►
8月
(1)
►
7月
(2)
►
6月
(1)
►
4月
(2)
►
3月
(1)
►
2月
(5)
►
1月
(1)
►
2023
(30)
►
12月
(3)
►
11月
(5)
►
10月
(2)
►
9月
(1)
►
8月
(2)
►
7月
(4)
►
6月
(2)
►
5月
(3)
►
4月
(2)
►
3月
(2)
►
2月
(3)
►
1月
(1)
►
2022
(106)
►
12月
(5)
►
11月
(1)
►
10月
(3)
►
9月
(6)
►
8月
(7)
►
7月
(6)
►
6月
(13)
►
5月
(9)
►
4月
(15)
►
3月
(11)
►
2月
(14)
►
1月
(16)
▼
2021
(85)
►
12月
(11)
►
11月
(6)
►
10月
(4)
▼
9月
(10)
MongoDB でフィールド同士を比較したい
MongoDB で更新後のドキュメントを返したい
[PowerShell] JSON の読み込み
[PowerShell] 文字列が null または空文字かどうか判定する
[Node.js] Windows で子プロセスを終了させる方法
[Python] datetime とタイムゾーンについてのメモ
[JavaScript] JSON の内容を文字列で出力する
[JavaScript] map で配列の値とインデックスを同時に取得する
[Python] http リクエストの送信
VSCode の Remote-Containers を起動したときに、マウントのパスに無効な文字が...
►
8月
(8)
►
7月
(4)
►
6月
(18)
►
5月
(7)
►
4月
(8)
►
3月
(2)
►
2月
(2)
►
1月
(5)
►
2020
(56)
►
12月
(1)
►
11月
(3)
►
10月
(3)
►
9月
(3)
►
8月
(3)
►
7月
(7)
►
6月
(7)
►
5月
(2)
►
4月
(6)
►
3月
(6)
►
2月
(3)
►
1月
(12)
►
2019
(92)
►
12月
(13)
►
11月
(9)
►
10月
(3)
►
9月
(2)
►
8月
(3)
►
7月
(5)
►
6月
(11)
►
5月
(6)
►
4月
(17)
►
3月
(9)
►
2月
(6)
►
1月
(8)
►
2018
(100)
►
12月
(1)
►
11月
(11)
►
10月
(8)
►
9月
(6)
►
8月
(10)
►
7月
(10)
►
6月
(8)
►
5月
(9)
►
4月
(8)
►
3月
(14)
►
2月
(4)
►
1月
(11)
►
2017
(117)
►
12月
(14)
►
11月
(20)
►
10月
(17)
►
9月
(19)
►
8月
(10)
►
7月
(8)
►
6月
(3)
►
5月
(6)
►
4月
(5)
►
3月
(2)
►
2月
(8)
►
1月
(5)
►
2016
(91)
►
12月
(5)
►
11月
(9)
►
10月
(11)
►
9月
(9)
►
8月
(6)
►
7月
(14)
►
6月
(14)
►
5月
(11)
►
4月
(10)
►
3月
(2)
►
2015
(23)
►
12月
(4)
►
11月
(2)
►
10月
(8)
►
9月
(8)
►
7月
(1)
►
2013
(3)
►
11月
(1)
►
9月
(1)
►
7月
(1)
►
2012
(2)
►
7月
(1)
►
6月
(1)
►
2011
(1)
►
9月
(1)
►
2009
(1)
►
7月
(1)
►
2008
(2)
►
11月
(1)
►
7月
(1)
►
2007
(3)
►
10月
(3)