问题描述
我需要收集条件元素列表以进行数据框查询, 我设法创建它如下:
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"])
)