解决pymongo里操作IOSDate类型的问题

pymongo是Python对MongoDB的操作库。但是由于python没有IOSDate类型,所以对Mongo的时间类型是个很麻烦的操作。整理一个把python能识别的date类型转化为IOSDate类型

1
2
3
4
5
6
7
8
9
10
脚本如下:
#!/usr/bin/python
import pymongo
from dateutil import parser
dateStr = '2018-06-12T00:00:00.000Z'
myDatetime = parser.parse(dateStr)
client = pymongo.MongoClient(host="192.168.2.14",port=29019)
db = client.dbs
db.authenticate()
db.ceshi.insert({'date': myDatetime})

 

到MongoDB里查看数据:

testin.dbs>db.ceshi.find()
  { "_id" : ObjectId("5b3054fa29e93634dcc21645"), "date" : ISODate("2018-06-12T00:00:00Z") }

已经插入ISODate格式时间。

 

 

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
import pymongo,datetime
from dateutil import parser
def findmongo():
    time1 = datetime.datetime.now()
 
    dateStr1 = '2019-01-21T00:00:00Z'
    dateStr2 = '2019-01-23T00:00:00Z'
    myDatetime1 = parser.parse(dateStr1)
    myDatetime2 = parser.parse(dateStr2)
 
    client = pymongo.MongoClient(host="0.0.0.0", port=3717)
    db = client.mongolilly
    db.authenticate("root","admin")
 
    a = db.current_temp.find({"order_id":"465","scan_time":{ "$gte": myDatetime1, "$lte":myDatetime2}})
    time2 = datetime.datetime.now()
    time3 = time2 - time1
    print "time3------->select_time :%s" % time3
 
    list = []
    for i in a :
        data = {
            "number": i["number"],
            "temperature": i["temperature"],
            "scan_time": i["scan_time"],
            "scan_location": i["scan_location"],
            "battery": i["battery"],
            "rssi": i["rssi"],
            "mac": i["mac"],
            "order_id": i["order_id"]
            # "id": str(one_info.id)
        }
        list.append(data)
 
    time4 = datetime.datetime.now()
    time5 = time4-time1
    print "time5------>all_time:",time5

 

posted @   割肉机  阅读(683)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
点击右上角即可分享
微信分享提示