Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Boa noite a todos. Seguinte, tenho um sistema em php que chama um script python e ao final esse script gera um arquivo de log, até ai ok, porém o arquivo de log está saindo com uma codificação maluca em algumas partes será que tem como resolver via PHP? Tentei ler o arquivo para o php e usar a função utf8_encode e nada.
Na imagem é possível perceber os quadrados, onde estão os quadrados deveriam ser valores.O script em python está correto não é erro lá não. Talvez alguma dependência ou versão do python da minha máquina tá fazendo gerar isso, porém já tentei solucionar testando diversas versões de tudo e não deu certo. Outro detalhe é que quando leio o arquivo em python ele mostra que onde tem os quadrados ele subsituti por \x1b...
Alguma ideia?

Não man, é gerado num script em python.
Matheus, vou falar meio que no escuro para tentar ajudar. Já faz um bom tempo que fiz um sistema que interagia com um switch via ssh e tenho lembranças vagas...
Então, esse hexadecimal \x1b se não me engano refere-se ao log do inpute da tecla ESC, se também bem me lembro o PHP não exibira esse valor, mas da você pode exibir o correspondente na tabela ASCII com a função ord("\x1b"); caso precise
Talvez isso seja útil:
http://php.net/manual/pt_BR/regexp.reference.escape.php
>
15 horas atrás, EdCesar disse:
Matheus, vou falar meio que no escuro para tentar ajudar. Já faz um bom tempo que fiz um sistema que interagia com um switch via ssh e tenho lembranças vagas...
Então, esse hexadecimal \x1b se não me engano refere-se ao log do impute da tecla ESC, se também bem me lembro o PHP não exibira esse valor, mas da você pode exibir o correspondente na tabela ASCII com a função ord("\x1b"); caso precise
Talvez isso seja útil:
http://php.net/manual/pt_BR/regexp.reference.escape.php
Boa tarde EdCesar. Obrigado pela resposta. Seguinte eu testei essa função. Fiz um código simples para ler o arquivo e imprimir por linha. Realmente ela convere os códigos ascii em inteiros, mas acredito que os números não estão corretos, fiquei meio em dúvida.
segue código.
$fp = fopen("orientationLog.log", "r");
while(!feof($fp)) {
$linha = fgets($fp, 4096);
echo ord($linha)."\n";
}
E tive isso como resultado:
50 27 49 49 49 49 49 49 49 27 27 27 27 27 27 27 27 27 77 49 49 27 49 50 27
Realmente a contagem está certa, no arquivo de log existem 25 números. Mas de acordo com meus resultados não estou certo que os números estão corretos não, pode ser alguma coisa que ainda precisa ser feita?
Abraços,
Matheus, joia!
Lembrando que a aspas simples trata tudo como string:
$caracter = "\x1b";
echo $caracter; // Exibira: � (Aquele quadradinho da imagem)
$caracter = '\x1b';
echo $caracter; // Exibira: \x1b
No caso fazendo a leitura de um arquivo de log, para exibir a string **\x1b**, isso seria uma possibilidade:
$fp = fopen("orientationLog.log", "r");
while(!feof($fp)) {
$linha = str_replace("'","",escapeshellarg(fgets($fp, 4096)));
echo ($linha)."\n";
}
Se a sua questão for algo mais do que exibir a string **\x1b**, conte-nos um pouco mais o que você pretende fazer, pois no caso de logs como a tecla backspace, enter, esc etc... você só conseguira exibir o seu equivalente em hexadecimal, decimal, octal ou binário de acordo com a tabela ASCII
Para confirmar se os números estão vindo corretos, faça um "de para" na tabela abaixo:
https://pt.wikipedia.org/wiki/ASCII
por exemplo, 50 em decimal equivale à 32 em hexa, que seu log deve estar como \x32
>
45 minutos atrás, EdCesar disse:
Matheus, joia!
Lembrando que a aspas simples trata tudo como string:
$caracter = "\x1b";
echo $caracter; // Exibira: � (Aquele quadradinho da imagem)
$caracter = '\x1b';
echo $caracter; // Exibira: \x1b
No caso fazendo a leitura de um arquivo de log, para exibir a string **\x1b**, isso seria uma possibilidade:
$fp = fopen("orientationLog.log", "r");
while(!feof($fp)) {
$linha = str_replace("'","",escapeshellarg(fgets($fp, 4096)));
echo ($linha)."\n";
}
Se a sua questão for algo mais do que exibir a string **\x1b**, conte-nos um pouco mais o que você pretende fazer, pois no caso de logs como a tecla backspace, enter, esc etc... você só conseguira exibir o seu equivalente em hexadecimal, decimal, octal ou binário de acordo com a tabela ASCII
Para confirmar se os números estão vindo corretos, faça um "de para" na tabela abaixo:
https://pt.wikipedia.org/wiki/ASCII
por exemplo, 50 em decimal equivale à 32 em hexa, que seu log deve estar como \x32
Olá EdCesar, então não acho que tenha relação com esse problema no momento as aspas. Fiz a leitura do arquivo em python no terminal para que você veja, todos os números do relatório são codificados como \x1b, talvez por isso aquele resultado repetitivo dos 25 números que coloquei mais acima. Não sei achei que ia resolver com sua dica inicial, mas acho que não vai não. Se você olhar a figura verá que está o relatório todo do programa e na hora que deveria aparecer um número aparece o \x1b.
Testei a função que você colocou acima, mas nada mudou os números saíram os mesmos.
Abraços,

Matheus, tentei fazer uma simulação desse seu arquivo de log, e imprimiu a string referente a tecla ESC, em hexadecimal, tanto no terminal quanto no navegador, conforme o print
Seria apenas isso o que você quer fazer? Tirando os problemas, qual o seu objetivo?

Olá EdCesar, então eu achei que essa codificação era de um número inteiro, era isso que eu queria fazer converter isso para o número real.
Abraços,
não dá pra gerar o negocim em php não?