前几天我发表了一篇文章,展示了如何为 Google 表格创建两个自定义公式以根据条件添加小时数(此处)。我认为他们的问题是不灵活。如果我想要 N 个条件怎么办?好吧,现在你可以了!
现在该公式采用 3 组数据:持续时间、条件和过滤器指令。 让我们回到测试电子表格:
标题 | 期间 | 类别 | 地位 | 喜欢 |
---|---|---|---|---|
火星人 | 01:00:00 | 电影 | 我已经看过了 | 是的 |
星际穿越 | 02:49:00 | 电影 | 我已经看过了 | 不 |
约翰威克 | 01:30:00 | 电影 | 我已经看过了 | 不 |
复仇者联盟:终局之战 | 03:00:00 | 电影 | 我想看 | |
怪奇物语 | 00:45:00 | 系列 | 参加 | |
巫师 | 01:00:01 | 系列 | 参加 | |
曼达洛人 | 00:40:00 | 系列 | 参加 | |
绝命毒师 | 00:50:00 | 系列 | 我已经看过了 | 是的 |
纸房子 | 00:55:00 | 系列 | 我想看 | |
权力的游戏 | 01:10:00 | 系列 | 我想看 |
让我们更新我们的应用程序脚本,我建议创建另一个测试电子表格并开始一个新的电子表格,记住时间必须采用“纯文本”。代码在这里:
/** * Converte uma string no formato HH:MM:SS para o total em segundos. * * @param {string} hms - A string no formato HH:MM:SS. * @returns {number} O total em segundos. */ function converterHMSParaSegundos(hms) { const partes = String(hms).split(":"); const [horas, minutos, segundos] = partes; return Number(horas) * 3600 Number(minutos) * 60 Number(segundos); } /** * Converte um número de segundos para o formato HH:MM:SS. * * @param {number} segundos - O total de segundos. * @returns {string} O tempo no formato HH:MM:SS. */ function converterSegundosParaHMS(segundos) { const horas = Math.floor(segundos / 3600); const minutos = Math.floor((segundos % 3600) / 60); const segundosRestantes = segundos % 60; return `${String(horas).padStart(2, "0")}:${String(minutos).padStart( 2, "0" )}:${String(segundosRestantes).padStart(2, "0")}`; } /** * Filtra as linhas da matriz de dados com base nos critérios fornecidos e retorna as durações correspondentes. * * @param {Array} duracoes - Array de durações em formato de texto. * @param {Array >} dados - Matriz de dados onde cada linha corresponde a um conjunto de valores. * @param {Array } criterios - Array de critérios para filtrar as linhas da matriz de dados. * @returns {Array } Retorna as durações que correspondem aos critérios. */ function filtroDeLinhas(duracoes, dados, criterios) { const linhas_na_matriz = duracoes.length; const matriz_de_criterios_concatenada = []; for (let linha = 0; linha } duracoes - Array de durações em formato de texto. * @param {Array >} intervalo_de_criterios - Matriz de dados onde cada linha corresponde a um conjunto de valores. * @param {...string} criterios - Um ou mais critérios para filtrar as linhas da matriz de dados. * @returns {string} A soma das durações no formato HH:MM:SS. */ function somarHorasComCriterios( duracoes, intervalo_de_criterios, ...criterios ) { // Verifica se todos os argumentos são arrays if ( !Array.isArray(duracoes) || !Array.isArray(intervalo_de_criterios) || !Array.isArray(criterios) ) { return "Passe os intervalos para o cálculo!"; } const horasParaSomar = filtroDeLinhas( duracoes, intervalo_de_criterios, criterios.flat(Infinity) ); const horasEmSegundos = horasParaSomar.map((n) => converterHMSParaSegundos(n) ); const somaDosSegundos = horasEmSegundos.reduce( (acumulador, valorAtual) => acumulador valorAtual, 0 ); return converterSegundosParaHMS(somaDosSegundos); }
假设我通过了:
电影 |我已经看过了 |不
我的总和是:04:19:00
并且请记住,我可以使用本机函数将其包装:=VALUE 并将其格式化为“持续时间”,并且工作表将返回到工作总和,就像使用本机公式一样!
正如我在上一篇文章中所说,请留下您的评论以及任何建议或问题。拥抱。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3