快速解决pymongo操作mongodb的时区问题
2020-12-09 04:06
1291 查看
如下所示:
1、mongodb的日期时间格式是UTC时间,中国时间 = UTC时间 +8
2、可在pymongo客户端加入时区以解决此问题:
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 按照时间查询
我就废话不多说了,大家还是直接看代码吧~
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的时区问题就是小编分享给大家的全部内容了,希望能给大家一个参考
您可能感兴趣的文章:相关文章推荐
- 【MongoDB】java操作MangoDB,实现时间搜索条件,解决ISODate的问题
- mongodb 操作命令 及常见问题解决方法 (更新中...)
- mongodb 时区问题及 Date 类型相关操作
- 快速移动鼠标触发问题及解决方法(ECharts外部调用保存为图片操作及工作流接线mouseenter和mouseleave)
- 关于nandflsh 快速对安全区操作一些问题及其解决
- Java 编程技术中汉字问题的分析及解决,文件操作
- 如何解决ADO.NET访问Access数据库出现"操作必须使用一个可更新的查询"的问题(非原创,摘自书中)
- 有关SQL排序规则---------即"无法解决 equal to 操作的排序规则冲突"等等的菜问题.
- 三层终于解决事务问题了。如果delphi由于种种原因在没落,不知道以后需要快速开发用什么工具最妥当了
- “以前的某个程序已在安装计算机上创建挂起的文件操作”的问题的解决方法...
- Ado.Net操作Excel文件数据常见问题及解决
- 基于java时区转换夏令时的问题及解决方法
- 如何解决ADO.NET访问Access数据库出现"操作必须使用一个可更新的查询"的问题
- 有关SQL排序规则---------即"无法解决 equal to 操作的排序规则冲突"等等的菜问题.
- 解决jboss的时区问题
- SuperMap属性表操作中遇到的Query结果为null的问题分析及解决
- SSH+AJAX项目 链接“Internet Explorer无法打开站点,已终止操作”问题的解决
- ASP.Net下如何解决关于Access数据库“操作必须使用一个可更新的查询”问题
- 教你轻松解决XP启动后操作迟延问题
- 快速解决问题的能力是何等的重要!