我正在将我的应用程序与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)
答案 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'])