我正在尝试使用python仅获取firestore中字段的值,但它返回一个键值对

时间:2019-03-22 07:50:23

标签: python python-3.x firebase google-cloud-firestore

我正在将我的应用程序与cloude firestore链接在一起,并且正在使用python,我需要检索值“ Balance”字段以检查其是否有效。但是当我尝试检索它时,会得到这样的输出

{ Balance: 80 }

但是我只需要余额的整数/浮点值。 我的代码如下-

import firebase_admin
from firebase_admin import credentials
from firebase_admin import firestore

# Use the application default credentials
cred = credentials.Certificate("/Users/admin/Downloads/serviceAccountKey.json")
firebase_admin.initialize_app(cred)

db = firestore.client()
user_id= 'my user id in database'
u = 80
userbal_new= u-10
users_ref = db.collection(u'users').document(user_id)

#update balance
#users_ref.update({u'Balance': userbal_new})

#get balance
get_bal= users_ref.get({u'Balance'})
bal = u'{}'.format(get_bal.to_dict())
print (bal)

3 个答案:

答案 0 :(得分:0)

因为您在此处使用to_dict函数:

bal = u'{}'.format(get_bal.to_dict())

这将生成一个字典,您可以像下面这样调用bal字典:

bal['Balance']

或者,以以下格式进行通话(如果您希望始终保持 余额)

bal = u'{}'.format(get_bal.to_dict()['Balance'])

答案 1 :(得分:0)

您可以通过传递db.collection().document().get(),用field_paths={}指定要在快照中返回的field_paths

get_bal = users_ref.get(field_paths={'Balance'}).to_dict()

这将仅返回字典中的余额:

{ Balance: 80 }

我找到了get()简易阅读器。因此,如果您只想要int。

bal = get_bal.get('Balance')

bal = users_ref.get(field_paths={'Balance'}).to_dict().get('Balance')

将返回

80

答案 2 :(得分:-1)

如果您得到bal = {'Balance':80} 然后为了获得余额使用.. print(bal ['Balance'])