如何解决dict 持有列表 - 列表理解
我需要收集条件元素列表以进行数据框查询, 我设法创建它如下:
column = ['TotalCharges','gender']
equal = ['>','==']
condition = [ 20,'F']
query = ' & '.join(f'{i} {j} {repr(k)}' for i,j,k in zip(column,equal,condition))
TotalCharges > 20 & gender == 'F'
哪个是必需的和正确的,
我很好奇如何使用字典持有列表来实现同样的事情, 意思
df_query_params = {"column":[],"equal":[],"condition":[]}
df_query_params["column"] = ['TotalCharges','gender']
df_query_params["equal"] = [ '>','==']
df_query_params["condition"] = [20,'F']
我尝试了类似的方法,使用 df_query_params.keys()
和 df_query_params.items()
但它不起作用,
让我对列表理解几乎没有迷失的事情 是我不知道如何“逐渐”添加更多嵌套元素,
解决方法
好吧,如果您只想对给定的字典使用推导式进行相同的查询,一种方法是使用 zip 遍历字典的值,并以类似的方式加入。
Exception in thread "main" java.lang.IllegalArgumentException: modifiers [] must contain one of [abstract,static,default]
at com.squareup.javapoet.Util.checkArgument(Util.java:53)
at com.squareup.javapoet.Util.requireExactlyOneOf(Util.java:85)
at com.squareup.javapoet.TypeSpec$Builder.build(TypeSpec.java:799)
at generator.content.ServiceGenerator.generateServiceTemplate(ServiceGenerator.java:32)
at generator.Generator.generate(Generator.java:28)
at Main.main(Main.java:13)
,
你只需要换掉裸名。
query = ' & '.join(
f'{i} {j} {repr(k)}'
for i,j,k in
zip(
df_query_params["column"],df_query_params["equal"],df_query_params["condition"])
)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。