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 / computer / Perguntas / 1421394
Accepted
John
John
Asked: 2019-04-05 05:26:25 +0800 CST2019-04-05 05:26:25 +0800 CST 2019-04-05 05:26:25 +0800 CST

Contando vírgulas em uma string de texto e adicionando uma nova linha

  • 772

Eu tenho um arquivo enorme (1400 páginas, uma única string de texto) que estou tentando tornar legível no Excel. O arquivo contém valores separados por vírgula, e colocar isso no Excel normalmente não é um problema, exceto que as informações devem estar em várias linhas no Excel e não todas na mesma linha do documento.

O que deveria ser uma linha de informação é separado por 115 vírgulas.

Meu plano era usar o Notepad ++ para contar 115 vírgulas, fazer uma nova linha, contar 115 vírgulas, fazer uma nova linha até percorrer todo o documento. Após esta operação deve ser fácil estruturá-lo no Excel. No entanto, tenho lutado para reunir as expressões necessárias.

Se houver outra maneira mais sensata de fazer isso, sou todo ouvidos, pode ser que esteja no caminho errado. Estou tentando usar a ferramenta localizar/substituir (CTRL+H) no Notepad++.

Eu tenho tentado usar "encontrar o que":

(,*?)\,{115}

O problema é que isso está procurando por 115 vírgulas consecutivas, mas preciso contar as 115 primeiras vírgulas em uma linha de texto e, em seguida, fazer uma paráfrase/nova linha e fazê-lo novamente. Qualquer ajuda / dicas seria muito apreciada. Eu tenho gasto muito tempo tentando encontrar as respostas.

notepad++ microsoft-excel-2010 csv
  • 3 3 respostas
  • 925 Views

3 respostas

  • Voted
  1. Best Answer
    Toto
    2019-04-05T06:57:37+08:002019-04-05T06:57:37+08:00
    • Ctrl+H
    • Encontrar o que:(?:.+?,){115}\K
    • Substitua por: \nou\r\n
    • verifique Enrole ao redor
    • verifique a expressão regular
    • NCHECK. matches newline
    • Replace all

    Explicação:

    (?:         # start non capture group
        .+?     # 1 or more any character, not greedy
        ,       # a comma
    ){115}      # end group, must appear 115 times
    \K          # forget all we have seen until this position
    

    Substituição:

    \n          # a line feed, change it to \r\n for windows files
    

    Isso manterá a vírgula no final de cada linha. Se você quiser removê-lo, use:

    (?:.+?,){114}.+?\K
    
    • 1
  2. Pavel Skipenes
    2019-04-05T07:21:42+08:002019-04-05T07:21:42+08:00

    coloque seu texto na variável inputstring e execute em python. Altere a variável numberofcolums com base em quantas colunas você deseja. Se você não tem o python instalado, pode usar uma ferramenta online como esta

    inputstring = "one, two, three, four,five,six,seven,eight,ten,etc,,,2342354,2,1,,,1,3,,,,"
    outputstring = ""
    
    numberofcolums = 115
    numberofcommas = 0
    
    print(inputstring)
    print(inputstring[3]!=",")
    for character in inputstring:
        if(character != ","):
            outputstring += character
        elif(numberofcommas == numberofcolums - 1):
            outputstring += ",\
            numberofcommas = 0
        else:
            outputstring += character
            numberofcommas += 1
    
    print(outputstring)
    
    • 0
  3. Raccoondude
    2019-04-05T05:35:52+08:002019-04-05T05:35:52+08:00

    Ok, o melhor a se fazer é fazer um script que resolva esse problema,

    Se entendi corretamente o seu problema, você precisa dividir uma string.

    Eu faria isso com a split()função pythons.

    depois, você pode fazer o Python escrever um arquivo e criar uma nova linha para cada parte de sua matriz que obteve da split()função.

    (não sou o melhor explicando, se precisar de ajuda posso fazer o roteiro para você, pergunte não deve demorar muito, é só pedir)

    • -1

relate perguntas

  • Removendo informações

  • Notepad ++ excluir até dois pontos para cada linha com substituir tudo

  • Contar o número de linhas que correspondem a vários critérios

  • NotePad++ User Defined Lang não mostra instruções condicionais

  • Como usar a função LENGTH do Excel para uma coluna inteira?

Sidebar

Stats

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

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    Serviço do Windows 10 chamado AarSvc_70f961. O que é e como posso desativá-lo?

    • 2 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Marko Smith

    ssl.SSLCertVerificationError: falha na verificação do certificado [SSL: CERTIFICATE_VERIFY_FAILED]: não foi possível obter o certificado do emissor local (_ssl.c:1056)

    • 4 respostas
  • Marko Smith

    Como posso saber em qual unidade o Windows está instalado?

    • 6 respostas
  • Martin Hope
    Albin Como faço para ativar o WindowsXP agora que o suporte acabou? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch O Windows 10 exclui muitos arquivos minúsculos muito lentamente. Algo pode ser feito para agilizar? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Como Ctrl+C e Ctrl+V funcionam? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

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