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 / unix / Perguntas / 701009
Accepted
NotTheDr01ds
NotTheDr01ds
Asked: 2022-05-01 22:22:03 +0800 CST2022-05-01 22:22:03 +0800 CST 2022-05-01 22:22:03 +0800 CST

Nushell: Converter lista de registros em tabela

  • 772

Nota de desambiguação: eu originalmente intitulei isso de "Nushell: Converter lista em tabela" (e alguns mecanismos de pesquisa têm isso como o primeiro resultado para essas palavras), no entanto, esta pergunta do Stack Overflow pode ser um exemplo melhor de "lista para tabela".


Existe uma maneira idiomática de converter uma lista de registros semelhantes em uma tabela no Nushell?

Estou trabalhando com a API do Stack Exchange e obtendo resultados como:

let questions = ('[
  {
    "tags":
    [
      "nushell"
    ],
    "title": "Nushell: Convert list to table"
  },
  {
    "tags":
    [
      "ssh",
      "tar"
    ],
    "title": "tar through ssh session",
    "closed_reason": "Duplicate"
  }
]' | from json)

Repare que closed_reasonsó é retornado para questões que foram encerradas, claro. Isso faz sentido -- Não há necessidade de a API desperdiçar largura de banda retornando campos vazios para a maioria das perguntas.

Mas como resultado, $questionstorna-se um list<any>em Nushell. Isso significa que uma operação como:

> $questions | group-by closed_reason

cannot find column... resulta em um erro (logicamente) .

Todos os resultados precisam ter a mesma estrutura para que isso funcione. Por exemplo, se todos os resultados tivessem closed_reason's, assim:

let questions = ('[
  {
    "tags":
    [
      "nushell"
    ],
    "title": "Nushell: Convert list to table",
    "closed_reason": ""
  },
  {
    "tags":
    [
      "ssh",
      "tar"
    ],
    "title": "tar through ssh session",
    "closed_reason": "Duplicate"
  }
]' | from json)

Então $questions | describefica:

table<tags: list<string>, title: string, closed_reason: string>

E $questions | group-by closed_reasonvai funcionar.

Existe alguma maneira de converter/"normalizar" a lista em uma tabela?

Eu tentei (com o original, list<any>resultado):

> $questions | table | group-by closed_reason
# obviously doesn't work, since the table command is just for rendering
# but worth a shot

> $questions | to csv | from csv | group-by closed_reason
# works, but loses the tag lists

> $questions | transpose | transpose | headers | reject column0 | to json
# Almost works, but still results in a list<any>
# since the first question's closed_reason becomes null
> $questions | transpose | transpose | headers | reject column0 | group-by closed_reason
# results in "can't convert nothing to string"
text-processing json
  • 2 2 respostas
  • 279 Views

2 respostas

  • Voted
  1. Kusalananda
    2022-05-02T00:34:50+08:002022-05-02T00:34:50+08:00

    Infelizmente não conheço o nushell. Ainda assim, você pode definitivamente passar os dados como JSON para jq, adicionar as chaves ausentes com valores de string vazios e convertê-los de volta para a representação interna do shell.

    Aqui estou atualizando a questionsvariável, mas você pode marcar o jqcomando no comando original letem vez de converter os dados de um lado para o outro desnecessariamente.

    let questions = ($questions | to json | jq '.[].closed_reason += ""' | from json)
    

    Então você pode agrupá-lo por closed_reason:

    〉$questions | group-by closed_reason
    ╭───────────┬───────────────╮
    │           │ [table 1 row] │
    │ Duplicate │ [table 1 row] │
    ╰───────────┴───────────────╯
    
    • 2
  2. Best Answer
    NotTheDr01ds
    2022-05-05T07:48:57+08:002022-05-05T07:48:57+08:00

    Finalmente encontrei a resposta. Eu estava procurando algo totalmente diferente com help --find def, quando vi o comando apropriadamente nomeado (mas não referenciado no Nushell Book) default, que é essencialmente um Nushell embutido para fazer a mesma coisa que @Kusalananda recomendou com jq.

    Portanto, o exemplo na pergunta pode ser corrigido via:

    > $questions | default "" closed_reason | group-by closed_reason
    ╭───────────┬───────────────╮
    │           │ [table 1 row] │
    │ Duplicate │ [table 1 row] │
    ╰───────────┴───────────────╯
    

    E o resultado é um objeto de tabela Nushell real:

    > $questions | default "" closed_reason | describe
    table<tags: list<string>, title: string, closed_reason: string>
    

    Com isso no lugar, posso começar a fazer alguns cortes e fatias na API do Stack:

    > $questions |
          default "" closed_reason | 
          where closed_reason == "Duplicate" |
          update tags { $in.tags | str collect ','}
          
    ╭───┬─────────┬─────────────────────────┬───────────────╮
    │ # │  tags   │          title          │ closed_reason │
    ├───┼─────────┼─────────────────────────┼───────────────┤
    │ 0 │ ssh,tar │ tar through ssh session │ Duplicate     │
    ╰───┴─────────┴─────────────────────────┴───────────────╯
    
    • 1

relate perguntas

  • Subtraindo a mesma coluna entre duas linhas no awk

  • chave de impressão jq e valor para todos no subobjeto

  • jq adicionar ou atualizar um valor com vários --arg

  • Embaralhamento de arquivo de várias linhas

  • como posso alterar o caso do caractere (de baixo para cima e vice-versa)? ao mesmo tempo [duplicado]

Sidebar

Stats

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

    Possível firmware ausente /lib/firmware/i915/* para o módulo i915

    • 3 respostas
  • Marko Smith

    Falha ao buscar o repositório de backports jessie

    • 4 respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    user12345 Falha ao buscar o repositório de backports jessie 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl Por que a maioria dos exemplos do systemd contém WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

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