gpt4 book ai didi

快速解决pymongo操作mongodb的时区问题

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章快速解决pymongo操作mongodb的时区问题由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

如下所示:

1、mongodb的日期时间格式是UTC时间,中国时间 = UTC时间 +8 。

2、可在pymongo客户端加入时区以解决此问题:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import pytz
from pymongo import MongoClient
from datetime import datetime
tzinfo = pytz.timezone( 'Asia/Shanghai' )
 
client = MongoClient(
   host = "127.0.0.1" ,
   port = 27017 ,
   username = "root" ,
   password = "123456" ,
   authSource = "admin" , # 在哪个数据库进行身份验证,默认是admin
   tz_aware = True , # 设置为True
   tzinfo = tzinfo  # 加入时区信息
)
db = client[ "test" ]
collection = db[ "mytest" ]
 
datetime.now() # 2020-04-11 10:42:42.452433
ret = collection.insert_one({
   "name" : "测试5" ,
   "create_time" : tzinfo.localize(datetime.now())
})
# create_time不能使用datetime.now()获取时间,
# 应该使用 datetime.utcnow()或 tzinfo.localize(datetime.now())或 datetime.now(tz=tzinfo)
# 这样读取数据时日期时间才是标准的中国时间
res = collection.find_one({ "name" : "测试5" })
print (res)
# {'_id': ObjectId('5e912ea261d252f76350728a'), 'name': '测试5', 'create_time': datetime.datetime(2020, 4, 11, 10, 42, 42, 452000, tzinfo=<DstTzInfo 'Asia/Shanghai' CST+8:00:00 STD>)}
 
# 下面测试直接使用datetime.now()的情形
datetime.now() # 2020-04-11 10:49:41.899445
collection.insert_one({
   "name" : "测试6" ,
   "create_time" : datetime.now()
})
res = collection.find_one({ "name" : "测试6" })
# {'_id': ObjectId('5e913045143015041d776d08'), 'name': '测试6', 'create_time': datetime.datetime(2020, 4, 11, 18, 49, 41, 899000, tzinfo=<DstTzInfo 'Asia/Shanghai' CST+8:00:00 STD>)}
# 可以看到时间+8小时

补充知识:pymongo 按照时间查询 。

我就废话不多说了,大家还是直接看代码吧~ 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
from pymongo import MongoClient
client = MongoClient( 'localhost' , 27017 )
db = client.adv.message
from datetime import datetime
import pandas as pd
#db.insert_one({'player_id':js2['player_id'],'message':js2['message'],
#        'label':label,'predict_time':datetime.datetime.now()})
 
#按照时间查询
q1 = { "predict_time" :{ "$gte" :datetime( 2019 , 9 , 25 ) , "$lte" : datetime( 2019 , 9 , 28 )}} 
l1 = list (db.find(q1))
 
#l1=list(db.find({}))
df = pd.DataFrame(l1)

以上这篇快速解决pymongo操作mongodb的时区问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.

原文链接:https://blog.csdn.net/qq_35556064/article/details/105448227 。

最后此篇关于快速解决pymongo操作mongodb的时区问题的文章就讲到这里了,如果你想了解更多关于快速解决pymongo操作mongodb的时区问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com