41

I've been trying to find a way to create an ISODate object whith pyMongo client, but without any success so far.

I use http://pypi.python.org/pypi/pymongo3 client, which is the only serious one available in Python 3 for now, but the problem doesn't seem to come from this specific pymongo version.

I'd like to know if any of you has found a solution to use this MongoDB object type from a pymongo client... thanks for your help !

Guillaume Lebourgeois
  • 3,796
  • 1
  • 20
  • 23
  • if you need to convert a date other than "now" , you may also want to add timezone info to your datetime , before getting the utc value – kommradHomer Feb 27 '15 at 16:20

5 Answers5

75

You just need to store an instance of datetime.datetime.

Inserting from the python shell:

>>> c.test.test.insert({'date': datetime.datetime.utcnow()})
ObjectId('4e8b388367d5bd2de0000000')
>>> c.test.test.find_one()
{u'date': datetime.datetime(2011, 10, 4, 16, 46, 59, 786000), u'_id': ObjectId('4e8b388367d5bd2de0000000')}

Querying in the mongo shell:

> db.test.findOne()
{
    "_id" : ObjectId("4e8b388367d5bd2de0000000"),
    "date" : ISODate("2011-10-04T16:46:59.786Z")
}
Bernie Hackett
  • 8,749
  • 1
  • 27
  • 20
15

For those who are wondering how to create ISODate from timestamp:

ts = time.time()
isodate = datetime.datetime.fromtimestamp(ts, None)

This will create datetime object with no timezone. When inserted to MongoDB it will get converted to proper ISODate().

Also, I strongly recommend looking at Python TimeTransitionsImage. Note that tuple here is named tuple (equivalent to struct in C). And also note that tuple fields are not the same as in C counterparts, even though the naming is the same (for instance, tm_wday starts with Monday and not Sunday).

johndodo
  • 17,247
  • 15
  • 96
  • 113
  • 9
    `fromtimestamp()` create a naive datetime object that represents time in the local timezone of your server: it is not what you want in most cases. You should use `datetime.utcfromtimestamp(ts)` instead. – jfs Aug 16 '15 at 23:17
4

Actually that does not work either. When you try to use either utcfromtimestamp or fromtimestamp, the program errors out saying that it needs a float. Just parse the string into a date time object and use that directly in the Mongodb. filter

from_dt = datetime.strptime('2018-04-01','%Y-%m-%d')
#from_dts = datetime.utcfromtimestamp(from_dt)
to_dt = datetime.strptime('2018-04-30','%Y-%m-%d')
#to_dts = datetime.utcfromtimestamp(to_dt)
filterCondition = { 
    "LastLogin" : { "$lte" : to_dt},
    "LastLogin" : { "$gte" : from_dt}
}

And then

db[(colName)].find({ "<colName>" : filterCondition }) 

Would work...

Kasia Gogolek
  • 3,374
  • 4
  • 33
  • 50
Sandip Sinha
  • 49
  • 1
  • 1
1
result = db.objects.insert_one(
   {"last_modified": datetime.datetime.utcnow()})

Here utc stands for Universal Time Coordinates.

Tyler
  • 740
  • 9
  • 27
  • 1
    Welcome to Stack Overflow. You could make this a better answer by adding some explanation of what the code is doing – Mark Chorley Jul 26 '16 at 15:26
0

For create a document with specific date, for example 03/10/1999, run this:

from datetime import datetime
from pymongo import MongoClient

db = MongoClient().db_name

date = datetime(1999, 03, 10)
db.collection.insert_one({'date': date})