Я могу создать новый документ (с автоматически сгенерированным идентификатором) и сохранить ссылку на него следующим образом:
my_data = {"key": "value"}
doc_ref = db.collection(u'campaigns').add(my_data)
Я могу получить доступ к самим данным, например:
print (doc_ref[0]) # prints {"key": "value"}
Но когда я пытаюсь получить доступ к идентификатору doc_ref, я не могу:
# All of these throw attribute errors
doc_ref.get()
doc_ref.data()
doc_ref.id
Есть и другие сообщения, которые предлагают, как это сделать в Javascript., но ни один из них не работает с Python SDK!
Как я могу получить доступ к сгенерированному идентификатору документа, который я создал?






Документация неясна, но я, наконец, заставил ее работать:
doc_ref = db.collection(u'campaigns').document()
doc_ref.set(my_data)
print(doc_ref.id)
Вы можете получить идентификатор из документа еще до вызова метода set
doc_ref = db.collection(u'campaigns').document()
id = doc_ref.id
Затем выполните, чтобы сохранить:
doc_ref(my_data)
Чтобы получить ID после сохранения на Python:
Это вернет, например, некоторый идентификатор, например wlJQKyVDsIIpX0x3NBmt
doc_ref = db.collection('promotions').add(data)
return doc_ref[1].id
Документации по этому вопросу очень мало, но мне удалось разобраться методом проб и ошибок.
Если вы хотите использовать метод add, как указано в вопросе, вместо ссылки на документ вместе с методом set попробуйте:
my_data = {"key": "value"}
response = db.collection(u'campaigns').add(my_data)
id = response[1].id
data = response[1].get().to_dict()
Ответ Firestore при использовании метода add содержит кортеж:
DatetimeWithNanoseconds объект - содержит время создания документаid и снимок документа, из которого вы можете извлечь данные документа, объединив get() и to_dict().
Так просто, и все же так трудно найти. Спасибо!