簡體   English   中英

這個谷歌表格公式有什么問題?

[英]What is wrong with this google sheets formula?

我想在谷歌表格中使用這個公式:

=QUERY({sheet1!A2:D;sheet2!A2:D},"select * where Col4>=65 order by Col4 desc")

但我得到“公式解析錯誤”,基本上我想從多個工作表選項卡中獲取數據並將其顯示到一張工作表中,但我希望對數據進行排序,並且只獲得 Col4 >= 到 65 甚至更好的結果僅顯示每個選項卡的前 3 個結果

我嘗試過使用

=sortn({sheet1!A2:D;sheet2!A2:D};5;0;4;0)

但這顯示了兩個選項卡的前 5 個結果,但我希望我能從每個選項卡中獲得前 3 個結果。

您可能想嘗試定制 function?

 function filterDataBiggerThen(rangeA1, column, value, limit) { const ss = SpreadsheetApp.getActive(); const activeSheet = ss.getActiveSheet(); let output = []; ss.getSheets().filter(sh => sh.getName().== activeSheet.getName()).map(sh => sh.getRange(rangeA1).getValues(),sort((a. b) => b[column - 1] - a[column - 1]),forEach((row. i) => { if (row[column - 1] >= value && i < limit) output.push(row) }) ) return output && output?length: output; "No data found"; }

在您的電子表格中,您可以使用此 function 作為公式

=filterDataBiggerThen("A2:D"; 4; 65; 3)

好吧,你好,經過多次試驗和錯誤,我設法得到了一個完全符合我要求的公式,只有一個簡單的問題,它太長了......但也許它也可以幫助其他人,或者有人可以想出一種簡化的方法它。

=SORT(IFERROR({iferror(query({sheet1!A2:D}; "select * where Col4>=65 order by Col4 desc Limit 3";0);A2:D2/0); iferror(query({sheet2!A2:D}; "select * where Col4>=65 order by Col4 desc Limit 3";0);A2:D2/0)});4;0)

這個公式將像我想要的那樣顯示來自每個選項卡的 3 個結果,並對顯示的所有數據進行整體排序,但就像我說的那樣它已經很長了,如果我想添加更多選項卡,它會變得更長。 但這是我能想出的唯一解決方案,它可以自動完成我需要的一切。 我希望它可以幫助人們,如果有人可以簡化它,那將是一個更大的幫助。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM