问题描述
使用以下命令,我可以从我的币安账户打印我的资产余额。
命令:
USDT_BAL = client.futures_account_balance(asset='USDT')
返回:
[{'accountAlias': 'sRuXXqTioCfWFz','asset': 'BNB','balance': '0.00000142','withdrawAvailable': '0.00000142','updateTime': 1621516315044},{'accountAlias': 'sRuXXqTioCfWFz','asset': 'USDT','balance': '0.00000000','withdrawAvailable': '0.00000000','updateTime': 0},'asset': 'BUSD','updateTime': 0}]
它返回其他资产的余额,但我只需要USDT资产的余额。我如何为其过滤 USDT_BAL 变量?
解决方法
扩展我的评论:
您的 list
为 dict
。 list
访问是通过迭代(for
循环)或索引完成的。 my_list[0]
等。
dict
访问也可以通过迭代完成,但一个很大的好处是键控访问。 my_dict['some_key']
等。
Python 简化了常见的 list
和 dict
构建方式,通常称为“理解”。
因此 list
可以理解为:
my_list = []
for i in range(10):
my_list.append(i)
可以写成
my_list = [i for i in range(10)]
我给您的不一定是list
理解,而是遵循相同的想法。它被称为“生成器表达式”。不同之处在于它在迭代时会生成一些输出,但它的整体输出不是某些内置集合(list
或 dict
)的形式。
在这种情况下有意义的原因是:
- 我需要遍历
list
以找到具有正确dict
键的'asset'
。 - 我预计这种情况只会发生一次,所以我只关心第一次发生。
所以要分解它,你有一个生成器表达式:
(i['balance'] for i in USDT_BAL if i['asset'] == 'USDT')
大致相当于。
def my_gen():
for i in USDT_BAL:
if i['asset'] == 'USDT':
yield i['balance']
或者如果您不熟悉生成器并希望将其作为 list
:
my_list = []
for i in USDT_BAL:
if i['asset'] == 'USDT':
my_list.append(i['balance'])
所以现在您可以看到我们遇到了问题。
如果我们将其作为 list
推导式,它的形式是带有一个元素的 list
。
print(my_list) # ['0.00000000']
我们可以使用 my_list[0]
访问它,但这在 IMO 看来很难看,但对每个人来说都是它自己的。
这就是 next
函数的用武之地。
根据 docs next
在迭代器(生成器是)上调用 __next__
方法并基本上推进生成器。
因此,如果我们的生成器生成 1
然后 2
然后 3
,调用 next(my_gen)
会生成 1
然后再次调用它会生成 2
和以此类推。
因为我希望这个生成器表达式只产生 1 个项目,所以我只调用它一次。给它一个默认值 None
意味着,如果它是空的,而不是引发错误,它会产生 None
。
所以:
next((i['balance'] for i in USDT_BAL if i['asset'] == 'USDT'),None)
创建一个迭代你的 list
的生成器,只生成 'balance'
的 dict
键,其 'asset'
键等于 'USDT'
并调用 {{1 }} 在该生成器上,默认值为 next
。