Python过滤字符串

问题描述

使用以下命令,我可以从我的币安账户打印我的资产余额。

命令:

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 变量?

解决方法

扩展我的评论:

您的 listdictlist 访问是通过迭代(for 循环)或索引完成的。 my_list[0] 等。

dict 访问也可以通过迭代完成,但一个很大的好处是键控访问。 my_dict['some_key'] 等。

Python 简化了常见的 listdict 构建方式,通常称为“理解”。

因此 list 可以理解为:

my_list = []
for i in range(10):
    my_list.append(i)

可以写成

my_list = [i for i in range(10)]

我给您的不一定是list 理解,而是遵循相同的想法。它被称为“生成器表达式”。不同之处在于它在迭代时会生成一些输出,但它的整体输出不是某些内置集合(listdict)的形式。

在这种情况下有意义的原因是:

  1. 我需要遍历 list 以找到具有正确 dict 键的 'asset'
  2. 我预计这种情况只会发生一次,所以我只关心第一次发生。

所以要分解它,你有一个生成器表达式:

(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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...