AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / coding / Perguntas / 79155608
Accepted
Romain Gapteau
Romain Gapteau
Asked: 2024-11-04 21:21:16 +0800 CST2024-11-04 21:21:16 +0800 CST 2024-11-04 21:21:16 +0800 CST

Classificar uma matriz 2D com uma matriz 1D no appscript

  • 772

Quero classificar uma matriz 2D com uma matriz 1D no AppScript.

para que a matriz 2D fique na mesma ordem que a matriz 1D.

Aí está o link da planilha do Google:

Matriz 1D
um
b
c
e
e
e
g
o
eu
eu
o
eu
Matriz 2D
b 156
e 68
um 507
c 22
e 430
e 555
g 689
o 62
eu 395
eu 209
eu 745
o 37

Eu uso o alfabeto como exemplo, mas no meu caso não é apenas a letra, mas o nome completo.

Tentei o script de outro post com o nome: "Classificar array de objetos por lista arbitrária em Javascript", mas não funciona, apenas me retorna meu array 2D sem classificá-lo.

o script que eu tento:

const objects = spreadsheetApp.getActive().getSheetByName("feuille 2").getRange('A;B').getValues()
const order = spreadsheetApp.getActive().getSheetByName("feuille 1").getRange('A;A').getValues()


const orderIndex = {}
order.forEach((value, index) => orderIndex[value] = index);

// Sort
objects.sort((a, b) => orderIndex[a.id] - orderIndex[b.id]);

// Log
console.log('orderIndex:', orderIndex);
console.log('objects:', objects);

Editar: Script que tentei com base na resposta, que não funcionou:

function myFunction() {

let objects = SpreadsheetApp.getActive().getSheetByName("Feuille 7").getRange('D:E').getValues()
let order = SpreadsheetApp.getActive().getSheetByName("Feuille 7").getRange('A:A').getValues().flat()

/* Create a mapping object `orderIndex`:
*/

let orderIndex = {}
order.forEach((value, index) => orderIndex[value] = index);

// Sort
objects.sort((a, b) => orderIndex[a] - orderIndex[b]) 

// Log
Logger.log("/////////////////////////order////////////////////////////////")
Logger.log(order)
Logger.log("/////////////////////////objects////////////////////////////////")
Logger.log(objects)


SpreadsheetApp.getActive().getSheetByName("Feuille 7").getRange('H:I').setValues(objects)
}
arrays
  • 3 3 respostas
  • 80 Views

3 respostas

  • Voted
  1. Best Answer
    TheMaster
    2024-11-04T21:33:13+08:002024-11-04T21:33:13+08:00

    orderé uma matriz 2D. getValues()sempre retorna uma matriz 2D, independentemente do tamanho do intervalo. flattransforme-a em uma matriz 1D:

    const order = spreadsheetApp.getActive().getSheetByName("feuille 1").getRange('A:A').getValues().flat()
    

    Não há idatributo em arrays 2D. Remova-o e obtenha o primeiro índice de cada array interno e classifique com base nele:

    objects.sort((a, b) => orderIndex[a[0]] - orderIndex[b[0]]);
    

    Também há um erro de digitação nas getRangechamadas: deveria ser A:Band A:A(dois pontos :- não ponto e vírgula ;)

    myFunction()
    
    function myFunction() {
    
    let objects = [['f',130],['b',5],['c',1]]
    let order = ['a','c','b','f']
    
    /* Create a mapping object `orderIndex`:
    */
    
    let orderIndex = {}
    order.forEach((value, index) => orderIndex[value] = index);
    
    // Sort
    objects.sort((a, b) => orderIndex[a[0]] - orderIndex[b[0]]) 
    Logger=console
    
    // Log
    Logger.log("/////////////////////////order////////////////////////////////")
    Logger.log(orderIndex)
    Logger.log("/////////////////////////objects////////////////////////////////")
    Logger.log(objects)
    }

    • 2
  2. doubleunary
    2024-11-05T05:37:57+08:002024-11-05T05:37:57+08:00

    A questão pergunta como classificar arrayna ordem personalizada especificada por order. No caso geral, onde os dois arrays podem conter um número diferente de itens, isso é difícil de fazer com Array.sort() , porque esse método só permite que você compare itens entre arraysi. A questão, no entanto, especifica que os itens devem ser comparados e classificados de acordo com order, que é um array diferente.

    Uma maneira de classificar arrayna ordem personalizada especificada por orderé usar Array.map(), assim:

    /**
    * Sorts a 2D array by the first column to the sequence shown by order.
    * Keys that do not appear in order are sorted to the top of the array.
    * Doesn't mutate array.
    *
    * @param {Object[][]} array The 2D array to sort.
    * @param {Object[]} order A 1D array that shows how to sort.
    * @return {Object[][]} Sorted copy of array.
    */
    function sortArrayByOrder_(array, order) {
      const sortIndex = array.map((row, i) => ({ i, index: order.indexOf(row[0]) }));
      sortIndex.sort((a, b) => a.index - b.index);
      return sortIndex.map((m) => array[m.i]);
    }
    

    Você pode usar a função assim:

    function test(objects, order) {
      const ss = SpreadsheetApp.getActive();
      if (!objects) objects = ss.getRange('feuille 2!A1:B').getValues();
      if (!order) order = ss.getRange('feuille 1!A1:A').getValues();
      const sorted = sortArrayByOrder_(objects, order.flat());
      console.log(sorted);
      return sorted;
    }
    

    Os resultados ficarão assim:

    captura de tela

    Observe como o posicionamento incomum de f, ee dse reflete no resultado.

    Veja Array.map() .

    • 1
  3. Cooper
    2024-11-05T01:18:57+08:002024-11-05T01:18:57+08:00
    function myfunk101() {
      const ss = SpreadsheetApp.getActive();
      const sh1 = ss.getSheetByName("Sheet0");
      const sh2 = ss.getSheetByName("Sheet1");
      const vs1 = sh1.getRange("A1:B" + sh1.getLastRow()).getDisplayValues();
      const vs2 = sh2.getRange("A1:A" + sh2.getLastRow()).getDisplayValues();
      vs1.sort((a,b) => {
        let va1 = a[0].localeCompare(b[0])     
        let va2 = 0;
        if(va1 === 0) {
          va2 = a[1].localeCompare(b[1],"en",{numeric:true})
        }
        return va1 + va2
      })
      vs2.sort((a,b) => a[0].localeCompare(b[0])) 
      Logger.log(JSON.stringify(vs1).replace(/],/g,'],\n'));
      Logger.log(JSON.stringify(vs2).replace(/],/g,'],\n'));
    }
    
    [["a","507"],
    ["b","156"],
    ["c","22"],
    ["d","430"],
    ["e","555"],
    ["f","68"],
    ["g","689"],
    ["h","37"],
    ["i","209"],
    ["j","745"],
    ["k","62"],
    ["l","395"]]
    [["a"],
    ["b"],
    ["c"],
    ["d"],
    ["e"],
    ["f"],
    ["g"],
    ["h"],
    ["i"],
    ["j"],
    ["k"],
    ["l"]]
    
    • localComparar
    • -1

relate perguntas

  • Possível inicializar um ponteiro de um valor na matriz de ponteiros?

  • Possível inicializar o ponteiro para a matriz de variáveis ​​digitadas?

  • Swift Array, como recuperar todos os elementos em uma enumeração aninhada de uma matriz

  • Por que uma string C nem sempre é equivalente a uma matriz de caracteres?

  • PowerShell: Como transformar valores de matriz hastable como este?

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Vue 3: Erro na criação "Identificador esperado, mas encontrado 'import'" [duplicado]

    • 1 respostas
  • Marko Smith

    Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle?

    • 1 respostas
  • Marko Smith

    Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores?

    • 1 respostas
  • Marko Smith

    Como faço para corrigir um erro MODULE_NOT_FOUND para um módulo que não importei manualmente?

    • 6 respostas
  • Marko Smith

    `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso?

    • 3 respostas
  • Marko Smith

    Quando devo usar um std::inplace_vector em vez de um std::vector?

    • 3 respostas
  • Marko Smith

    Um programa vazio que não faz nada em C++ precisa de um heap de 204 KB, mas não em C

    • 1 respostas
  • Marko Smith

    PowerBI atualmente quebrado com BigQuery: problema de driver Simba com atualização do Windows

    • 2 respostas
  • Marko Smith

    AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos

    • 1 respostas
  • Marko Smith

    Estou tentando fazer o jogo pacman usando apenas o módulo Turtle Random e Math

    • 1 respostas
  • Martin Hope
    Aleksandr Dubinsky Por que a correspondência de padrões com o switch no InetAddress falha com 'não cobre todos os valores de entrada possíveis'? 2024-12-23 06:56:21 +0800 CST
  • Martin Hope
    Phillip Borge Por que esse código Java simples e pequeno roda 30x mais rápido em todas as JVMs Graal, mas não em nenhuma JVM Oracle? 2024-12-12 20:46:46 +0800 CST
  • Martin Hope
    Oodini Qual é o propósito de `enum class` com um tipo subjacente especificado, mas sem enumeradores? 2024-12-12 06:27:11 +0800 CST
  • Martin Hope
    sleeptightAnsiC `(expression, lvalue) = rvalue` é uma atribuição válida em C ou C++? Por que alguns compiladores aceitam/rejeitam isso? 2024-11-09 07:18:53 +0800 CST
  • Martin Hope
    The Mad Gamer Quando devo usar um std::inplace_vector em vez de um std::vector? 2024-10-29 23:01:00 +0800 CST
  • Martin Hope
    Chad Feller O ponto e vírgula agora é opcional em condicionais bash com [[ .. ]] na versão 5.2? 2024-10-21 05:50:33 +0800 CST
  • Martin Hope
    Wrench Por que um traço duplo (--) faz com que esta cláusula MariaDB seja avaliada como verdadeira? 2024-05-05 13:37:20 +0800 CST
  • Martin Hope
    Waket Zheng Por que `dict(id=1, **{'id': 2})` às vezes gera `KeyError: 'id'` em vez de um TypeError? 2024-05-04 14:19:19 +0800 CST
  • Martin Hope
    user924 AdMob: MobileAds.initialize() - "java.lang.Integer não pode ser convertido em java.lang.String" para alguns dispositivos 2024-03-20 03:12:31 +0800 CST
  • Martin Hope
    MarkB Por que o GCC gera código que executa condicionalmente uma implementação SIMD? 2024-02-17 06:17:14 +0800 CST

Hot tag

python javascript c++ c# java typescript sql reactjs html

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve