快速解決pymongo操作mongodb的時區(qū)問題
更新時間:2020年12月05日 11:19:11 作者:一屋不碼,何以碼天下
這篇文章主要介紹了快速解決pymongo操作mongodb的時區(qū)問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
如下所示:
1、mongodb的日期時間格式是UTC時間,中國時間 = UTC時間 +8
2、可在pymongo客戶端加入時區(qū)以解決此問題:
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", # 在哪個數(shù)據(jù)庫進行身份驗證,默認是admin tz_aware=True, # 設置為True tzinfo=tzinfo # 加入時區(qū)信息 ) 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) # 這樣讀取數(shù)據(jù)時日期時間才是標準的中國時間 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的時區(qū)問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Python機器學習利用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線
這篇文章主要為大家介紹了Python機器學習利用鳶尾花數(shù)據(jù)繪制ROC和AUC曲線實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-02-02詳解win10下pytorch-gpu安裝以及CUDA詳細安裝過程
這篇文章主要介紹了win10下pytorch-gpu安裝以及CUDA詳細安裝過程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01Python實現(xiàn)數(shù)字圖像處理染色體計數(shù)示例
這篇文章主要為大家介紹了Python實現(xiàn)數(shù)字圖像處理染色體計數(shù)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06VSCode基礎使用與VSCode調試python程序入門的圖文教程
這篇文章主要介紹了VSCode基礎使用+VSCode調試python程序入門圖文教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03Python用zip函數(shù)同時遍歷多個迭代器示例詳解
這篇文章主要給大家進行介紹了Python如何用zip函數(shù)同時遍歷多個迭代器,文中給出了示例以及原理和注意事項,相信會對大家的理解和學習很有幫助,有需要的朋友們下面來一起學習學習吧。2016-11-11