0
我想通过查询填写一个网格区域。但我希望此查询根据下拉列表的选择进行更改。我有三个不同的查询,我希望他们根据下拉进行交换。使用IFS()在查询语句之间切换
我试图使用IFS如下面的查询之间进行切换:
=iferror(
IFS(B9="Value",
query(LOG!A4:U,"SELECT A, B, C, D, E, F, G, H, I, J, K WHERE A Is Not Null "
& IF(ISBLANK(B4),"", " AND K='"& LEFT(B4,7) &"'") & " "
& IF(D6<>"ALL", " AND N ='"& D6 &"'", "") & " "
& IF(E6<>"ALL", " AND Q ='"& E6 &"'", "") & " "
& IF(F6<>"ALL", " AND P ='"& F6 &"'", "") & " "
& IF(G6<>"ALL", " AND O ='"& G6 &"'", "") & " "
& IF(H6<>"ALL", " AND R ='"& H6 &"'", "") & " "
& IF(I6<>"ALL", " AND S ="& I6, "") & " "
& IF(ISBLANK(J6), "", " AND T ='"& LEFT(J6,7) &"'") & " "
& IF(ISBLANK(H9), "", " AND C >= date '" & text(H9,"yyyy-MM-dd") & "'") & " "
& IF(ISBLANK(I9), "", " AND D <= date '" & text(I9,"yyyy-MM-dd") & "'") & " "
,-1),
B9 = "value 2",
"other query
,"NO RESULTS")
那么单元格的值是不是查询的价值,而这个公式只返回B9的价值。
有没有办法根据单元格的下拉选择执行不同的查询?
在此先感谢
编辑1:
=IFS(B9="WITHOUT COURSE"
,FILTER(PERSONNEL!A6:J
,(ISERROR(Match(PERSONNEL!A6:A,UNIQUE(filter(LOG!K4:K, VALUE(LOG!J4:J) = VALUE(RIGHT(B6,12)))),0)))
, (PERSONNEL!F6:F = E6) + (E6 = "ALL")
, (D6 = "ALL") + (PERSONNEL!D6:D = D6)
, (F6 = "ALL") + (PERSONNEL!G6:G = F6)
, (G6 = "ALL") + (PERSONNEL!E6:E = G6)
, (H6 = "ALL") + (PERSONNEL!I6:I = H6)
, (I6 = "ALL") + (PERSONNEL!H6:H = I6)
)
,B9="WITH COURSE"
,query(LOG!A4:U,"SELECT A, B, C, D, E, F, G, H, I, J, K WHERE A Is Not Null "
& IF(ISBLANK(B4),"", " AND K='"& LEFT(B4,7) &"'") & " "
& IF(D6<>"ALL", " AND N ='"& D6 &"'", "") & " "
& IF(E6<>"ALL", " AND Q ='"& E6 &"'", "") & " "
& IF(F6<>"ALL", " AND P ='"& F6 &"'", "") & " "
& IF(G6<>"ALL", " AND O ='"& G6 &"'", "") & " "
& IF(H6<>"ALL", " AND R ='"& H6 &"'", "") & " "
& IF(I6<>"ALL", " AND S ="& I6, "") & " "
& IF(ISBLANK(J6), "", " AND T ='"& LEFT(J6,7) &"'") & " "
& IF(ISBLANK(H9), "", " AND C >= date '" & text(H9,"yyyy-MM-dd") & "'") & " "
& IF(ISBLANK(I9), "", " AND D <= date '" & text(I9,"yyyy-MM-dd") & "'") & " "
& IF(ISBLANK(B6), "", " AND J ='"& RIGHT(B6,12) &"'") & " "
& IF(ISBLANK(B7), "", " AND L ='"& RIGHT(B7,12) &"'") & " "
& IF(ISBLANK(B8), "", " AND M ='"& B8 &"'") & " "
& IF(B9 = "EXPIRES IN", " AND (DATEDIFF(now(), C)/30) >= U AND U > 0 AND (DATEDIFF(now(), C)/30) <= " &E9 & " " ,"")
,-1)
)
你错过了分号:''other query“'? –
我看不到一个;在opffical文档https://support.google.com/docs/answer/7014145?hl=zh_CN中,如果我添加一个,它会自动删除 –
对不起,我的意思是双引号“查询”后的单词' –