O programa Python falha apenas se for executado (via ssh) a partir de um terminal mac

O programa Python falha apenas se for executado (via ssh) a partir de um terminal mac

Estou tentando executar um programa python em um cluster de processamento de dados (Linux). O programa funciona bem se eu fizer ssh para o cluster a partir do meu desktop Linux e iniciá-lo, mas falhará se eu fizer ssh para o cluster a partir do meu laptop Mac e tentar executá-lo, recebo o seguinte erro:

[muzzle@cluster]~% acme-calibrate detector DARK --in-folder /gpfs/acme/exp/instrument/201802/experiment1/raw --out-folder /home/muzzle/dark_out --run 28
Traceback (most recent call last):
  File "/home/boff/calframework/framework/extern/bin/acme-calibrate", line 11, in <module>
    load_entry_point('acme-Offline-Calibration', 'console_scripts', 'acme-calibrate')()
  File "/home/boff/calframework/framework/extern/lib/python3.4/site-packages/setuptools-39.1.0-py3.4.egg/pkg_resources/__init__.py", line 480, in load_entry_point
  File "/home/boff/calframework/framework/extern/lib/python3.4/site-packages/setuptools-39.1.0-py3.4.egg/pkg_resources/__init__.py", line 2691, in load_entry_point
  File "/home/boff/calframework/framework/extern/lib/python3.4/site-packages/setuptools-39.1.0-py3.4.egg/pkg_resources/__init__.py", line 2322, in load
  File "/home/boff/calframework/framework/extern/lib/python3.4/site-packages/setuptools-39.1.0-py3.4.egg/pkg_resources/__init__.py", line 2328, in resolve
  File "/home/boff/pycalibrate_tmp/acme_calibrate/calibrate.py", line 236, in <module>
nb = nbformat.read(f, as_version=4)
  File "/home/boff/calframework/framework/extern/lib/python3.4/site-packages/nbformat/__init__.py", line 141, in read
return reads(fp.read(), as_version, **kwargs)
  File "/home/boff/calframework/framework/extern/lib/python3.4/encodings/ascii.py", line 26, in decode
return codecs.ascii_decode(input, self.errors)[0]
UnicodeDecodeError: 'ascii' codec can't decode byte 0xc4 in position 150: ordinal not in range(128)

Parece estar relacionado a alguma conversão de UTF para ASCII, mas estou fora do meu alcance.

Recebo o mesmo erro com terminal.app e iterm2. A propósito, eu costumava ter a integração do shell iterm2 instalada, mas os removi agora.

A localidade no laptop é:

$ locale
LANG=
LC_COLLATE="C"
LC_CTYPE="UTF-8"
LC_MESSAGES="C"
LC_MONETARY="C"
LC_NUMERIC="C"
LC_TIME="C"
LC_ALL=

A localidade no servidor remoto é:

% locale
locale: Cannot set LC_CTYPE to default locale: No such file or directory
locale: Cannot set LC_ALL to default locale: No such file or directory
LANG=en_US.UTF-8
LC_CTYPE=UTF-8
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=

Esta é a localidade no meu desktop Linux, é idêntica à do cluster:

$ locale
LANG=en_GB.UTF-8
LANGUAGE=en_GB:en
LC_CTYPE="en_GB.UTF-8"
LC_NUMERIC="en_GB.UTF-8"
LC_TIME="en_GB.UTF-8"
LC_COLLATE="en_GB.UTF-8"
LC_MONETARY="en_GB.UTF-8"
LC_MESSAGES="en_GB.UTF-8"
LC_PAPER="en_GB.UTF-8"
LC_NAME="en_GB.UTF-8"
LC_ADDRESS="en_GB.UTF-8"
LC_TELEPHONE="en_GB.UTF-8"
LC_MEASUREMENT="en_GB.UTF-8"
LC_IDENTIFICATION="en_GB.UTF-8"
LC_ALL=

Responder1

Parece que a solução correta foi desmarcar "Definir variáveis ​​de ambiente de localidade na inicialização" nas opções avançadas do terminal, conforme descrito emhttps://blog.remibergsma.com/2012/07/10/setting-locales-correctly-on-mac-osx-terminal-application/

Para fazer a mesma coisa no iterm2 você deve desmarcar Preferências > Perfis > Terminal > Definir variáveis ​​de localidade automaticamente, conforme descrito aquihttps://apple.stackexchange.com/questions/83428/lang-variable-wrong-in-iterm2-wheres-the-bug

Responder2

A postagem Problemas UTF-8 do Terminal OS X tem alguns conselhos úteis, baseados em Um guia para ajudar a configurar aplicativos de terminal:

  1. EmTerminal->Preferências->Configurações->Avançado:

    • SobInternacional, certifique-se de que a codificação de caracteres esteja definida comoUnicode (UTF-8).

    • SobEmulação, Garanta queEscape da entrada não ASCII com Control-Vénãodefinir.

    Isso por si só pode ser suficiente para resolver o problema.

  2. Use o comando localee observe a LC_CTYPElinha, que deve terminar com .UTF-8. Caso contrário, no bash .profileou .bashrcno diretório inicial, adicione uma linha como esta:

    export LC_CTYPE=your-locale-here.UTF-8
    
  3. Adicione as seguintes linhas ao .inputrcdiretório inicial (crie-o se necessário):

    set meta-flag on
    set input-meta on
    set output-meta on
    set convert-meta off
    

Você precisa reiniciar o bash para que as novas configurações tenham efeito.

informação relacionada