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[jq](coding)

Martin Hope
Nick S
Asked: 2025-04-12 00:56:44 +0800 CST

JQ e campos múltiplos com um SELECT

  • 6

Digamos que eu tenha um json retornado assim:

export json_string='{
    "summary": "1 failure",
    "checks": [
        {
            "id": "check1",
            "status": "OK"
        },
        {
            "id": "check2",
            "status": "FAILED"
        },
        {
            "id": "check3",
            "status": "CONFIG_WARNING"
        }
    ]
}'

Como faço para obter o resumo e o cheque que não foi devolvido? Posso obter o cheque que não foi devolvido por meio de algo como:

echo "$json_string" | jq '.checks | .[] | select(.status != "OK")'

Mas eu realmente gostaria de obter o resumo e as verificações com falha, ou apenas o resumo se não houver falhas.

ATUALIZAÇÃO A resposta aceita me apontou na direção certa. Aqui está o comando que acabei usando para formatar a saída como eu queria:

echo "$json_string" | jq '{"summary": .summary, "checks":[.checks[] | select(.status != "OK")]}'
jq
  • 2 respostas
  • 32 Views
Martin Hope
Alexandros
Asked: 2025-03-08 18:19:36 +0800 CST

Extraia a chave "pacotes" da saída do skopeo com jq

  • 5

Estou tentando extrair a lista de pacotes da saída do skopeo inspect, mas isso parece não funcionar:

❯ skopeo inspect docker://ghcr.io/ublue-os/bluefin-dx:gts | jq '.Labels."dev.hhd.rechunk.info".packages'

O acima funciona sem a parte ".packages" e o conteúdo é:

❯ skopeo inspect docker://ghcr.io/ublue-os/bluefin-dx:gts | jq '.Labels."dev.hhd.rechunk.info"'
"{\"version\": 2, \"uniq\": \"gts-40.20250305\", \"packages\": {\"libgcc\": \"14.2.1-3.fc40\", .....

Como posso pedir para o jq entrar neste objeto e extrair apenas a parte "pacotes"?

jq
  • 1 respostas
  • 24 Views
Martin Hope
user-id-14900042
Asked: 2025-02-08 18:42:15 +0800 CST

Como transformar um objeto recursivo marcado em pares de marca e caminho absoluto?

  • 5

Como faço para transformar um objeto recursivo { id, name: { data }, children: self[] }em uma matriz de algo como { id: id, name: name.data | join('/') }?

Por exemplo, eu gostaria de converter os seguintes dados fornecidos

[
    {"id": "1", "name": { "data": "foo" }, "children": [] },
    {"id": "2", "name": { "data": "bar" }, "children": [
        {"id": "4", "name": { "data": "melon" }, "children": [
            {"id": "5", "name": { "data": "soda" }, "children": [] }
        ] }
    ] },
    {"id": "3", "name": { "data": "baz" }, "children": [
        {"id": "6", "name": { "data": "my data" }, "children": [] }
    ] }
]

em:

{"id": "1", "name": "foo"},
{"id": "2", "name": "bar"},
{"id": "4", "name": "bar/melon"},
{"id": "5", "name": "bar/melon/soda"},
{"id": "3", "name": "baz"},
{"id": "6", "name": "baz/my data"},

Não me importo com ordens de elementos, porque cada idobjeto fornecido tem um valor único em cada entrada.

Minha tentativa é

.. | (.children? // empty) | .[] | { id: .id, name: .name.data }

mas isso produz o nome da camada única (ou seja foo, bar, melon, ...).

jq
  • 1 respostas
  • 30 Views
Martin Hope
Eponymous
Asked: 2025-01-02 07:11:18 +0800 CST

Item de objeto e itens de matriz aninhados na mesma linha de saída

  • 6

Tenho alguns dados parecidos com estes:

{
"data": [
    {
      "startTime": "2024-12-31T00:00:00Z",
      "data": [
        {
          "one": "a",
          "two": 1125.000
        },
        {
          "one": "b",
          "two": 2119.000
        },
        {
          "one": "c",
          "two": 0.000
        }
      ]
    },

com vários objetos no array de dados externo. O que estou falhando é em produzir algo como isto:

startTime, one, two

que no caso dos dados acima me daria três linhas de saída. Eu posso obter um e dois juntos, mas não startTime: comjq -r '.data[] | "\(.startTime)", (.data[] | "\(.one), \(.two)" )'

2024-12-31T00:00:00Z
a, 1125.000
b, 2119.000
c, 0.000

jq -r '.data[] | "\(.startTime)", (.data[] | "\(.one), \(.two)" )'me dá o seguinte, iterando sobre cada um dos últimos itens ("dois"):

2024-12-31T00:00:00Z, a, 1125.000
2024-12-31T00:00:00Z, b, 1125.000
2024-12-31T00:00:00Z, c, 1125.000
2024-12-31T00:00:00Z, a, 2119.000
2024-12-31T00:00:00Z, b, 2119.000
2024-12-31T00:00:00Z, c, 2119.000
2024-12-31T00:00:00Z, a, 0.000
2024-12-31T00:00:00Z, b, 0.000
2024-12-31T00:00:00Z, c, 0.000

Não consigo encontrar a sintaxe correta.

jq
  • 1 respostas
  • 38 Views
Martin Hope
az5112
Asked: 2024-12-11 04:35:05 +0800 CST

Como usar .fieldname para jq's startswith

  • 5

No script jq abaixo, quero imprimir a concatenação de e first_nameou last_nameapenas last_name.

$ echo '{"first_name": "John", "last_name": "Johnson"}' | jq -c '{
  "name": (if (.last_name | startswith(.first_name)) 
           then .last_name 
           else .first_name + " " + .last_name 
           end)
}'

O erro é

jq: error (at <stdin>:1): Cannot index string with string "first_name"

O comando jq falha na chamada para startswith- como se startswithaceitasse apenas literais de string. Se eu mudar startswith(.first_name)para startswith("John")então a expressão compila e funciona como esperado.

No exemplo do mundo real, há muitos registros de entrada e muitos first_names diferentes. Existe uma maneira de eu conectar .first_nameem startswith?

jq
  • 1 respostas
  • 14 Views
Martin Hope
Fravadona
Asked: 2024-12-07 03:26:22 +0800 CST

Substituindo a condição select por `IN` do jq

  • 5

Dada a entrada simplificada:

[
  [ "gpu" ],
  [ "disk" ]
]

Gostaria de selecionar as matrizes cujo primeiro elemento é "gpu".

Posso fazer isso com uma condição simples:

map(select(.[0] == "gpu"))
[
  [ "gpu" ]
]

Mas não entendo o que há de errado quando tento usar o INbuiltin:

map(select(.[0] | IN(["gpu"])))
[]

Estou usando jq1.6

jq
  • 1 respostas
  • 33 Views
Martin Hope
AJM.MARTINEZ
Asked: 2024-12-03 01:18:03 +0800 CST

Analisando saída json com JQ - Procurando padrões

  • 5

Tenho o seguinte JSON (com base na saída NDPI)

{
    "src_ip": "x.x.x.x",
    "dest_ip": "x1.x1.x1.x1",
    "src_port": 48318,
    "dst_port": 443,
    "ip": 4,
    "proto": "TCP",
    "ndpi": {
        "flow_risk": {
            "35": {
                "risk": "Susp Entropy",
                "severity": "Medium",
                "risk_score": {
                    "total": 210,
                    "client": 165,
                    "server": 45
                }
            }
        },
        "confidence": {
            "1": "Match by port"
        },
        "proto": "TLS",
        "proto_id": "91",
        "proto_by_ip": "Unknown",
        "proto_by_ip_id": 0,
        "encrypted": 1,
        "breed": "Safe",
        "category_id": 5,
        "category": "Web"
    },
    "detection_completed": 1,
    "check_extra_packets": 0,
    "flow_id": 0,
    "first_seen": 1733074272.824,
    "last_seen": 1733074282.757,
    "duration": 9.933,
    "vlan_id": 0,
    "bidirectional": 1,
    "xfer": {
        "data_ratio": -0.958,
        "data_ratio_str": "Download",
        "src2dst_packets": 1268,
        "src2dst_bytes": 86239,
        "src2dst_goodput_bytes": 2551,
        "dst2src_packets": 2693,
        "dst2src_bytes": 4042956,
        "dst2src_goodput_bytes": 3865218
    },
    "iat": {
        "flow_min": 1,
        "flow_avg": 6.1,
        "flow_max": 4005,
        "flow_stddev": 108.3,
        "c_to_s_min": 0,
        "c_to_s_avg": 7.4,
        "c_to_s_max": 4005,
        "c_to_s_stddev": 137.8,
        "s_to_c_min": 0,
        "s_to_c_avg": 1.4,
        "s_to_c_max": 35,
        "s_to_c_stddev": 2.2
    },
    "pktlen": {
        "c_to_s_min": 66,
        "c_to_s_avg": 68.0,
        "c_to_s_max": 514,
        "c_to_s_stddev": 28.8,
        "s_to_c_min": 66,
        "s_to_c_avg": 1501.3,
        "s_to_c_max": 1506,
        "s_to_c_stddev": 76.6
    },
    "tcp_flags": {
        "cwr_count": 0,
        "ece_count": 0,
        "urg_count": 0,
        "ack_count": 3961,
        "psh_count": 1323,
        "rst_count": 0,
        "syn_count": 0,
        "fin_count": 0,
        "src2dst_cwr_count": 0,
        "src2dst_ece_count": 0,
        "src2dst_urg_count": 0,
        "src2dst_ack_count": 1268,
        "src2dst_psh_count": 7,
        "src2dst_rst_count": 0,
        "src2dst_syn_count": 0,
        "src2dst_fin_count": 0,
        "dst2src_cwr_count": 0,
        "dst2src_ece_count": 0,
        "dst2src_urg_count": 0,
        "dst2src_ack_count": 2693,
        "dst2src_psh_count": 1316,
        "dst2src_rst_count": 0,
        "dst2src_syn_count": 0,
        "dst2src_fin_count": 0
    },
    "c_to_s_init_win": 0,
    "s_to_c_init_win": 0
}

Posso obter quase todas as informações (src_ip, portas, etc.), mas há uma coisa relacionada ao "flow_risk"

{"flow_risk": {"35": {"risk":"Susp Entropy","severity":"Medium"

que está relacionado ao número (neste caso 35). Este número pode ser diferente (de 01 a 50) e não sei como filtrar para buscar números diferentes.

No momento, esse é o filtro que estou usando

cat data.json | jq -r '"\(.src_ip),\(.src_port),\(.dest_ip),\(.dst_port),\(.proto),\(.ndpi.proto),\(.ndpi.category),\(.ndpi.hostname),\(.duration),\(.vlan_id),\(.xfer.src2dst_bytes),\(.xfer.dst2src_bytes),\(.ndpi.flow_risk."35".risk),\(.ndpi.flow_risk."35".severity)"')

Isso funciona quando o número é exatamente 35, mas há alguma chance de usar algo como curingas com jQ?

Quero dizer, como posso fazer isso para aceitar vários números? (por exemplo: pesquisar de 01 a 50?)

Algo como

\(.ndpi.flow_risk."*".risk),\(.ndpi.flow_risk."*".severity)"')

obrigado !

jq
  • 2 respostas
  • 30 Views
Martin Hope
P.Lonnie
Asked: 2024-11-26 05:45:52 +0800 CST

calcula valores numéricos consecutivos, mas falha devido a números de ponto flutuante comando jq

  • 6

Com um campo Json como o abaixo, se eventId for um valor contínuo, gostaria de adicionar o valor do campo de mensagem.

Entretanto, mesmo que eventId seja contínuo, se o campo de mensagem começar com # Hora, o campo de mensagem será separado.

Este é o campo original do Json.

{
    "events": [
        {
            "message": "# Time: 1",
            "eventId": "38636469249093328935961608873790523617989208925384015872"
        },
        {
            "message": ", 2, 3",
            "eventId": "38636469249093328935961608873790523617989208925384015873"
        },
        {
            "message": "# Time: 11",
            "eventId": "38636469249093328935961608873790523617989208925384015875"
        },
        {
            "message": "# Time: 12",
            "eventId": "38636469249093328935961608873790523617989208925384015876"
        },
        {
            "message": "# Time: A",
            "eventId": "1"
        },
        {
            "message": ", B, C",
            "eventId": "2"
        },
        {
            "message": "# Time: C",
            "eventId": "3"
        },
        {
            "message": "# Time: D",
            "eventId": "5"
        }
    ]
}

É assim que eu quero que fique:
[
  {
    "message": "# Time: 1, 2, 3"
  },
  {
    "message": "# Time: 11"
  },
  {
    "message": "# Time: 12"
  },
  {
    "message": "# Time: A , B, C"
  },
  {
    "message": "# Time: C"
  },
  {
    "message": "# Time: D"
  }
]

Já fiz uma pergunta sobre isso antes e recebi uma resposta de uma ótima pessoa. (Obrigado pmf.)
Depois disso, tentei o meu melhor para refinar um pouco mais, mas não funcionou, então perguntei mais uma vez.

Primeiro, quando executei este JQ pela primeira vez, obtive os seguintes resultados.

jq -r '.events 
| reduce .[1:][] as $i (.[:1];
    if ((.[-1].eventId | tonumber + 1 | tostring) != $i.eventId) or ($i.message | startswith("# Time:")) then
        . += [$i]
    else
        .[-1].message += " " + $i.message
    end
) 
| del(.[].eventId)
'
[
  {
    "message": "# Time: 1"
  },
  {
    "message": ", 2, 3"
  },
  {
    "message": "# Time: 11"
  },
  {
    "message": "# Time: 12"
  },
  {
    "message": "# Time: A , B, C"
  },
  {
    "message": "# Time: C"
  },
  {
    "message": "# Time: D"
  }
]

Eu vi isso como um problema de ponto flutuante e queria comparar esse número com a própria string, então criei uma função como a seguinte, mas não funcionou.
jq '
# Function to add one to a large number represented as a string
def add_one(num):
  (num | split("") | reverse | map(tonumber)) as $digits
  | reduce range(0; length) as $i ([];
      . + if $i == 0 or .[-1] == 10 then
            [($digits[$i] + 1) % 10]
         else
            [$digits[$i]]
         end
    )
  | reverse | map(tostring) | join("");

# Process events and check continuity
.events 
| map(.eventId |= tostring) # Ensure all eventIds are strings
| reduce .[1:][] as $i (.[:1];
    if (add_one(.[-1].eventId) != $i.eventId) or ($i.message | startswith("# Time:")) then
        . += [$i]
    else
        .[-1].message += " " + $i.message
    end
)
| del(.[].eventId)
'
[
  {
    "message": "# Time: 1"
  },
  {
    "message": ", 2, 3"
  },
  {
    "message": "# Time: 11"
  },
  {
    "message": "# Time: 12"
  },
  {
    "message": "# Time: A"
  },
  {
    "message": ", B, C"
  },
  {
    "message": "# Time: C"
  },
  {
    "message": "# Time: D"
  }
]

Pesquisando mais, encontrei um comando chamado gojq, mas gostaria de testá-lo primeiro para ver se é possível com jq.

Estou usando o jq versão 1.7.1.

jq
  • 1 respostas
  • 36 Views
Martin Hope
maximelian1986
Asked: 2024-11-13 20:34:35 +0800 CST

Classificando e comparando arquivos json com ./jq

  • 5

Estou tentando comparar dois arquivos json longos com o WinMerge usando o plugin QueryJSON. As propriedades nesses arquivos estão em ordem aleatória. Esse parâmetro para .\jq funciona, mas objetos aninhados não são afetados:

QueryJSON ". | to_entries | sort_by(.key) | from_entries"

Há um comando "flatten" que não me forneceu o resultado que procurei (pode estar sendo usado incorretamente).

Jsons poderiam ser, por exemplo:

{
   "Id": 1,
   "Addresses":[
      {"Street": "Street 1",
      "PostalCode": 12345},
      {"Street": "Street 2",
      "PostalCode": 12345}
   ],
   "Person":{
      "FirstName": "Mike",
      "LastName":"Boe"
   }
}


{
   "Id": 2,
   "Person":{
      "FirstName": "John",
      "LastName":"Boe"
   }
   "Addresses":[
      {"Street": "Street 3",
      "PostalCode": 12345},
      {"Street": "Street 2",
      "PostalCode": 12345}
   ]
}

Posso comparar objetos aninhados um por um apontando para eles como

QueryJSON ".Person | to_entries | sort_by(.key) | from_entries"

Mas há alguma maneira de classificar propriedades também dentro desses objetos (mesmo que isso os achataria)? Obrigado.

jq
  • 1 respostas
  • 31 Views
Martin Hope
tink
Asked: 2024-11-11 07:22:37 +0800 CST

Verificação de igualdade sem distinção entre maiúsculas e minúsculas em `jq`

  • 6

Encontrei o seguinte nas páginas do github govc govmomi , que me permite pesquisar VMs por endereço MAC:

govc object.collect -json -type m / config.hardware.device \
  | jq -r '
      .
      | select(.ChangeSet[].Val.VirtualDevice[].MacAddress == "00:50:56:bc:5e:3c")
      | [.Obj.Type, .Obj.Value]
      | join(":")
    ' \
  | xargs govc ls -L

Em anexo, segue um trecho da saída do govc que deve ser suficiente:

{
  "Obj": {
    "Type": "VirtualMachine",
    "Value": "vm-666"
  },
  "ChangeSet": [
    {
      "Val": {
        "VirtualDevice": [
          {
          },
          {
            "MacAddress": "00:50:56:bc:5e:3c"
          }
        ]
      }
    }
  ]
}

O problema que estou enfrentando é que alguns MACs contêm letras maiúsculas, algumas minúsculas, e não sei com antecedência qual máquina usa qual esquema. Não consigo descobrir como fazer com que o ==caso não seja sensível.

Encontrei respostas aqui no stackoverflow que sugerem usar ascii_downcasecomo filtro, mas não sei como aplicar isso com o ==.

A sintaxe sugerida em https://stackoverflow.com/a/62454688 me dá uma sequência de explode input must be a stringerros (1 por linha de saída do govc).

Caso isso seja importante para este exercício: isso está acontecendo em Mac OS 15.1, jqé instalado via brew, a versão é 1.7.1.

jq
  • 3 respostas
  • 72 Views

Sidebar

Stats

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

    Reformatar números, inserindo separadores em posições fixas

    • 6 respostas
  • Marko Smith

    Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não?

    • 2 respostas
  • Marko Smith

    Problema com extensão desinstalada automaticamente do VScode (tema Material)

    • 2 respostas
  • Marko Smith

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

    • 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

    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
  • Martin Hope
    Fantastic Mr Fox Somente o tipo copiável não é aceito na implementação std::vector do MSVC 2025-04-23 06:40:49 +0800 CST
  • Martin Hope
    Howard Hinnant Encontre o próximo dia da semana usando o cronógrafo 2025-04-21 08:30:25 +0800 CST
  • Martin Hope
    Fedor O inicializador de membro do construtor pode incluir a inicialização de outro membro? 2025-04-15 01:01:44 +0800 CST
  • Martin Hope
    Petr Filipský Por que os conceitos do C++20 causam erros de restrição cíclica, enquanto o SFINAE antigo não? 2025-03-23 21:39:40 +0800 CST
  • Martin Hope
    Catskul O C++20 mudou para permitir a conversão de `type(&)[N]` de matriz de limites conhecidos para `type(&)[]` de matriz de limites desconhecidos? 2025-03-04 06:57:53 +0800 CST
  • Martin Hope
    Stefan Pochmann Como/por que {2,3,10} e {x,3,10} com x=2 são ordenados de forma diferente? 2025-01-13 23:24:07 +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

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