Python 过滤字符串

Python filter string

使用以下命令,我可以从我的 binance ac 中打印我的资产余额。

命令:

USDT_BAL = client.futures_account_balance(asset='USDT')

Return:

[{'accountAlias': 'sRuXXqTioCfWFz', 'asset': 'BNB', 'balance': '0.00000142', 'withdrawAvailable': '0.00000142', 'updateTime': 1621516315044}, {'accountAlias': 'sRuXXqTioCfWFz', 'asset': 'USDT', 'balance': '0.00000000', 'withdrawAvailable': '0.00000000', 'updateTime': 0}, {'accountAlias': 'sRuXXqTioCfWFz', 'asset': 'BUSD', 'balance': '0.00000000', 'withdrawAvailable': '0.00000000', 'updateTime': 0}]

是returns其他资产的余额,而我只需要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 以使用正确的 'asset' 键找到 dict
  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] 访问它,但在我看来这看起来很丑陋,但对每个人来说它都是自己的。

这就是 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 的生成器,只生成 dict'balance' 键,'asset' 键等于 'USDT' 并调用 next 在该生成器上,默认值为 None.