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 变量?
扩展我的评论:
您的 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
以使用正确的 'asset'
键找到 dict
。
- 我预计这种情况只会出现一次,所以我只关心第一次出现的情况。
所以要分解它,你有一个生成器表达式:
(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
.
使用以下命令,我可以从我的 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 变量?
扩展我的评论:
您的 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
以使用正确的'asset'
键找到dict
。 - 我预计这种情况只会出现一次,所以我只关心第一次出现的情况。
所以要分解它,你有一个生成器表达式:
(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
.