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 / user-274554

Chris's questions

Martin Hope
Chris
Asked: 2020-01-24 07:23:29 +0800 CST

substituir strings em colunas com base em outros valores de arquivo

  • 0

Arquivo de entrada:

col01 20083d70-1bf0-40f4-9df9-6247d587c085 text text
col02 d233d76d-e60d-442e-9b44-f0e1dc9ebefb text text
col03 20083d70-1bf0-40f4-9df9-6247d587c085 text text
col04 20083d70-1bf0-40f4-9df9-6247d587c085 text text
col05 b26063fa-93e4-414d-82f2-7c2924c81cc6 text text
col06 dc3e2f9b-05bf-49b4-a63e-c4bc09524eb3 text text
col07 d9f5cf1d-a8f9-488d-b088-b7ad00b67ec6 text text
col08 b26063fa-93e4-414d-82f2-7c2924c81cc6 text text
col09 d9a558ff-494a-4ada-8ec2-e9b2f9178599 text text
col10 b26063fa-93e4-414d-82f2-7c2924c81cc6 text text
col11 b26063fa-93e4-414d-82f2-7c2924c81cc6 text text
col12 4d78f804-18f6-4cc8-98a3-c4aedc60aebf text text
col13 0fe487fe-2ff2-4ca4-adf8-de3c19115dde text text
col14 581207a4-f4a5-4373-806b-0e1f7c298bb1 text text

arquivo de referência:

0fe487fe-2ff2-4ca4-adf8-de3c19115dde group1
20083d70-1bf0-40f4-9df9-6247d587c085 group2
4d78f804-18f6-4cc8-98a3-c4aedc60aebf group3
581207a4-f4a5-4373-806b-0e1f7c298bb1 group4
b26063fa-93e4-414d-82f2-7c2924c81cc6 group5
d233d76d-e60d-442e-9b44-f0e1dc9ebefb group6
d9a558ff-494a-4ada-8ec2-e9b2f9178599 group7
d9f5cf1d-a8f9-488d-b088-b7ad00b67ec6 group8
dc3e2f9b-05bf-49b4-a63e-c4bc09524eb3 group9

saída esperada:

col01 20083d70-1bf0-40f4-9df9-6247d587c085(group2) text text
col02 d233d76d-e60d-442e-9b44-f0e1dc9ebefb(group6) text text
col03 20083d70-1bf0-40f4-9df9-6247d587c085(group2) text text
col04 20083d70-1bf0-40f4-9df9-6247d587c085(group2) text text
col05 b26063fa-93e4-414d-82f2-7c2924c81cc6(group5) text text
col06 dc3e2f9b-05bf-49b4-a63e-c4bc09524eb3(group9) text text
col07 d9f5cf1d-a8f9-488d-b088-b7ad00b67ec6(group8) text text
col08 b26063fa-93e4-414d-82f2-7c2924c81cc6(group5) text text
col09 d9a558ff-494a-4ada-8ec2-e9b2f9178599(group7) text text
col10 b26063fa-93e4-414d-82f2-7c2924c81cc6(group5) text text
col11 b26063fa-93e4-414d-82f2-7c2924c81cc6(group5) text text
col12 4d78f804-18f6-4cc8-98a3-c4aedc60aebf(group3) text text
col13 0fe487fe-2ff2-4ca4-adf8-de3c19115dde(group1) text text
col14 581207a4-f4a5-4373-806b-0e1f7c298bb1(group4) text text

agora eu posso conseguir isso com sed -iloop while:

$ cat reference|while read a b;do sed -i s/"$a"/"$a($b)"/ input;done

Poderia ser feito de uma maneira mais fácil, usando apenas o awk e sem o loop while, usando o arquivo de entrada e referência no processamento do comando awk único alterando os valores apenas na segunda coluna?

awk gawk
  • 1 respostas
  • 40 Views
Martin Hope
Chris
Asked: 2019-09-05 23:16:20 +0800 CST

jq - múltiplo se

  • 1

arquivo json de entrada:

[
  {
    "id": "1e9b2215-9efd-67cc-9113-1e21c74f09d3",
    "login": "u0159",
    "name": "Pat ABC",
    "role": "User",
    "groups": null,
    "disabled": false,
    "lLoginTime": 1567158950468,
    "lLoginFrom": "192.168.100.11"
  },
  {
    "id": "1e9b2215-9efd-67cc-9113-2b21c74f09d3",
    "login": "u0154",
    "name": "Roman ABC",
    "role": "User",
    "groups": [
      {
        "id": "1e8dc82a-596f-623c-8bc5-100000000000",
        "name": "Default ABC"
      },
      {
        "id": "1e99833f-9876-65d0-9d24-237228b9d9e0",
        "name": "AGE"
      }
    ],
    "disabled": false,
    "lLoginTime": 1567158950468,
    "lLoginFrom": "192.168.100.11"
  },
  {
    "id": "1e9b2215-9c2b-64f4-a0f1-47abdab7ae5f",
    "login": "u0155",
    "name": "Tomas CDE",
    "role": "User",
    "groups": [
      {
        "id": "1e8dc82a-596f-623c-8bc5-100000000000",
        "name": "ZZZ"
      },
      {
        "id": "1e8dc82a-596f-623c-8bc5-100000000000",
        "name": "Default ABC"
      },
      {
        "id": "1e99234f-9876-65d0-9d24-534528b9d9e0",
        "name": "NTE"
      }
    ],
    "disabled": false,
    "lLoginTime": 1566302653093,
    "lLoginFrom": "192.168.100.16"
  }
]

Eu quero estender o seguinte filtro:

$ jq -r '.[]|[.id, .login, ( if .groups == null then "n/a" else ([.groups[].name]|join("|")) end )]|@tsv' /tmp/test__
1e9b2215-9efd-67cc-9113-1e21c74f09d3    u0159   n/a
1e9b2215-9efd-67cc-9113-2b21c74f09d3    u0154   Default ABC|AGE
1e9b2215-9c2b-64f4-a0f1-47abdab7ae5f    u0155   ZZZ|Default ABC|NTE

para se livrar de todos os "ABC padrão" da lista de grupos separados por | na saída

Eu tentei com if adicional, mas ele falha com erro:

$ jq -r '.[]|[.id, .login, ( if .groups == null then "n/a" else ( if .groups[].name != "Default ABC" then [.groups[].name]|join("|")) end ) end )]|@tsv' /tmp/test__
jq: error: syntax error, unexpected ')' (Unix shell quoting issues?) at <top-level>, line 1:

agradeço qualquer dica...

a saída esperada para o json de amostra é:

1e9b2215-9efd-67cc-9113-1e21c74f09d3    u0159   n/a
1e9b2215-9efd-67cc-9113-2b21c74f09d3    u0154   AGE
1e9b2215-9c2b-64f4-a0f1-47abdab7ae5f    u0155   ZZZ|NTE

Atualização: Solução fornecida pela oliv:

$ jq -r '.[]|[.id,.login,if .groups then (.groups|map(select(.name != "Default ABC").name)|join("|")) else "n/a" end]|@tsv' /tmp/test__
1e9b2215-9efd-67cc-9113-1e21c74f09d3    u0159   n/a
1e9b2215-9efd-67cc-9113-2b21c74f09d3    u0154   AGE
1e9b2215-9c2b-64f4-a0f1-47abdab7ae5f    u0155   ZZZ|NTE
json jq
  • 1 respostas
  • 2710 Views
Martin Hope
Chris
Asked: 2019-09-04 03:00:41 +0800 CST

filtro jq remova ou substitua a guia de dentro do @tsv

  • 1

Insira o json:

[
  {
    "id": "1e9b2215-9efd-67cc-9113-2b21c74f09d3",
    "login": "u0154",
    "name": "Roman ABC",
    "role": "User",
    "groups": [
      {
        "id": "1e99833f-9876-65d0-9d24-237228b9d9e0",
        "name": "AGE"
      }
    ],
    "disabled": false,
    "lLoginTime": 1567158950468,
    "lLoginFrom": "192.168.100.11"
  },
  {
    "id": "1e9b2215-9c2b-64f4-a0f1-47abdab7ae5f",
    "login": "u0155",
    "name": "Tomas CDE",
    "role": "User",
    "groups": [
      {
        "id": "1e8dc82a-596f-623c-8bc5-100000000000",
        "name": "ZZZ"
      },
      {
        "id": "1e99234f-9876-65d0-9d24-534528b9d9e0",
        "name": "NTE"
      }
    ],
    "disabled": false,
    "lLoginTime": 1566302653093,
    "lLoginFrom": "192.168.100.16"
  }
]

Preciso imprimir .id, .login e todos os grupos de usuários separados por tabulação | (tubo) ou vírgula

O que tenho agora:

$ jq -r '.[]|[.id, .login, ([.groups[].name]|@tsv)]|@tsv' test.json
1e9b2215-9efd-67cc-9113-2b21c74f09d3    u0154   AGE
1e9b2215-9c2b-64f4-a0f1-47abdab7ae5f    u0155   ZZZ\tNTE

Eu preciso modificar o filtro para que os grupos que estão na última coluna sejam separados com espaço ou |em vez do atual\t

json jq
  • 1 respostas
  • 642 Views
Martin Hope
Chris
Asked: 2019-06-27 13:02:13 +0800 CST

"sort -nu" em uuids

  • 3

alguém poderia explicar por que "sort -nu" retorna apenas 1 linha exclusiva no exemplo abaixo?

$ cat /tmp/test_
1e971713-31e4-62d0-a3d1-37c0610c10e5
1e97d59f-bc32-6126-b7b1-0b52ddd35273
1e971713-31e4-62d0-a3d1-37c0610c10e5
$ sort -nu /tmp/test_
1e971713-31e4-62d0-a3d1-37c0610c10e5
$

não deveria haver duas linhas únicas na saída como em "sort -u"?

$ sort -u /tmp/test_
1e971713-31e4-62d0-a3d1-37c0610c10e5
1e97d59f-bc32-6126-b7b1-0b52ddd35273
$
sort uuid
  • 1 respostas
  • 439 Views
Martin Hope
Chris
Asked: 2019-05-11 00:37:04 +0800 CST

PIPESTATUS de comandos em $(...|...)

  • 3

Como ler ${PIPESTATUS[0]um comando, quando uma variável é definida no shell atual? Existe uma maneira de passá-lo para o shell atual de alguma forma?

Estou definindo a variável MAIL=$(ldapsearch.... | find_for_mail)e quero ter certeza se ldapsearchnão falhou antes de decidir que o atributo mail não existe realmente no LDAP.

$ true | false
$ echo ${PIPESTATUS[0]} ${PIPESTATUS[1]}
0 1
$ Z=$(true | false)
$ echo ${PIPESTATUS[0]}
1                        <--- why 1?
$ echo ${PIPESTATUS[1]}

$ Z=$(true | false;echo ${PIPESTATUS[0]} ${PIPESTATUS[1]})
$ echo $Z
0 1
$ Z=$(true | false;C="${PIPESTATUS[0]} ${PIPESTATUS[1]}")
$ echo $C

$ Z=$(true | false;export C="${PIPESTATUS[0]} ${PIPESTATUS[1]}")
$ echo $C
bash shell-script
  • 2 respostas
  • 1421 Views
Martin Hope
Chris
Asked: 2018-06-25 09:48:43 +0800 CST

substituir guia por espaço

  • 1

entrada json:

[
  {
    "name": "cust1",
    "grp": [
      {
        "id": "46",
        "name": "BA2"
      },
      {
        "id": "36",
        "name": "GA1"
      },
      {
        "id": "47",
        "name": "NA1"
      },
      {
        "id": "37",
        "name": "TR3"
      },
      {
        "id": "38",
        "name": "TS1"
      }
    ]
  }
]

como obter nomes .grp[] separados por espaço na saída @tsv?

$ jq -r '.[]|[.name, (.grp//[{"name":"-"}]|.[]|" ",.name)]|@tsv' test_inp
cust1           BA2             GA1             NA1             TR3             TS1

saída esperada para a amostra acima:

cust[TAB]BA2[SPACE]GA1[SPACE]NA1[SPACE]TR3[SPACE]TS1
json jq
  • 1 respostas
  • 263 Views
Martin Hope
Chris
Asked: 2018-06-24 13:17:25 +0800 CST

jq - converte milissegundos

  • 0

entrada json:

{
  "id": "3885",
  "login": "050111",
  "lastLoginTime": 1529730115000,
  "lastLoginFrom": "192.168.66.230"
}
{
  "id": "3898",
  "login": "050112",
  "lastLoginTime": null,
  "lastLoginFrom": null
}

O filtro funciona quando o lastlogintime existe:

$ jq -jr --arg ARG1 050111 'select(.login==$ARG1)|"user:", " ",.login,"\n","lastlogintime:", " ",(.lastLoginTime / 1000 | strftime("%Y-%m-%d %H:%M UTC")),"\n","lastloginfrom:", " ",.lastLoginFrom // "-","\n"' test_json3
user: 050111
lastlogintime: 2018-06-23 05:01 UTC
lastloginfrom: 192.168.66.230

mas há um problema (não imprime "-") quando lastlogintime não existe:

$ jq -jr --arg ARG1 050112 'select(.login==$ARG1)|"user:", " ",.login,"\n","lastlogintime:", " ",(.lastLoginTime / 1000 | strftime("%Y-%m-%d %H:%M UTC")),"\n","lastloginfrom:", " ",.lastLoginFrom // "-","\n"' test_json3
user: 050112
jq: error (at test_json3:12): null (null) and number (1000) cannot be divided

como pular a operação de divisão para lastlogintimes vazios?

json jq
  • 1 respostas
  • 3379 Views
Martin Hope
Chris
Asked: 2018-06-24 11:34:57 +0800 CST

jq - imprime valores em uma linha

  • 20

entrada json:

[
  {
    "name": "cust1",
    "grp": [
      {
        "id": "46",
        "name": "BA2"
      },
      {
        "id": "36",
        "name": "GA1"
      },
      {
        "id": "47",
        "name": "NA1"
      },
      {
        "id": "37",
        "name": "TR3"
      },
      {
        "id": "38",
        "name": "TS1"
      }
    ]
  }
]

esperado, na saída são duas linhas:

name: cust1
groups: BA2 GA1 NA1 TR3 TS1

Eu estava tentando construir filtro sem sucesso..

$ jq -r '.[]|"name:", .name, "groups:", (.grp[]|[.name]|@tsv)' test_json
name:
cust1
groups:
BA2
GA1
NA1
TR3
TS1

Atualização: a solução fornecida abaixo funciona bem, mas não previ o caso quando não existe nenhum grupo:

[
  {
    "name": "cust1",
    "grp": null
  }
]

nesse caso, a solução fornecida retorna erro:

$ jq -jr '.[]|"name:", " ",.name, "\n","groups:", (.grp[]|" ",.name),"\n"' test_json2
name: cust1
jq: error (at test_json2:6): Cannot iterate over null (null)

qualquer solução é apreciada.

json jq
  • 2 respostas
  • 43132 Views
Martin Hope
Chris
Asked: 2018-06-24 08:04:50 +0800 CST

jq - imprime "-" para valores nulos

  • 24

entrada json:

{
  "id": "3885",
  "login": "050111",
  "lastLoginTime": 1529730115000,
  "lastLoginFrom": "192.168.66.230"
}
{
  "id": "3898",
  "login": "050112",
  "lastLoginTime": null,
  "lastLoginFrom": null
}

Eu quero obter saída para login, lastLoginTime e lastLoginFrom no formato delimitado por tabulação:

050111  1529730115000   192.168.66.230
050112              -                -

com o filtro jq abaixo, recebo na saída nenhum valor "null" que eu poderia substituir por "-"

$ jq -r '.|[.login, .lastLoginTime, .lastLoginFrom]|@tsv' test_json
050111  1529730115000   192.168.66.230
050112

Existe alguma outra maneira de obter "-" impresso para esses valores nulos?

json jq
  • 2 respostas
  • 18608 Views
Martin Hope
Chris
Asked: 2018-05-12 10:57:04 +0800 CST

jq - selecione um atributo começando com uma string

  • 60

entrada json:

[
  {
    "id": "89",
    "hostname": "abcd"
  },
  {
    "id": "89",
    "hostname": "babcd"
  }
]

Como modificar o filtro abaixo para obter apenas o nome do host começando com "abcd"?

$ jq -r '.[]|select(.hostname | contains("abcd"))' jjjj
{
  "id": "89",
  "hostname": "abcd"
}
{
  "id": "89",
  "hostname": "babcd"
}
$ jq -r '.[]|select(.hostname | contains("^abcd"))' jjjj
$
json jq
  • 1 respostas
  • 64854 Views
Martin Hope
Chris
Asked: 2018-04-25 11:54:23 +0800 CST

alterar prompts de alteração de senha

  • 0

Existe uma maneira de alterar um prompt padrão exibido durante o processo de alteração de senha quando a senha já expirou? no centos e rhel? Eu gostaria de mudar (current) UNIX password:para Your previous password:ou Enter expired password: O prompt original engana muitos usuários que estão perguntando qual senha eles devem inserir nesta etapa (eles já inseriram a senha expirada antiga durante o login, pouco antes deste aviso de expiração e prompt serem exibidos e novamente solicitam velho em (current) UNIX password:)

Changing password for user.
(current) UNIX password:
New password:
Retype new password:
rhel centos
  • 1 respostas
  • 715 Views

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