2013-12-13 4 views
19

Wenn R in rApache ausgeführt wird, wird das Gebietsschema vom Apache-Webserver geerbt, und daher ist Sys.getlocale() immer gleich "C". Ich würde meine Web-Anwendung wie UTF8 zu verwenden, so dass ich verwenden:Gebietsschema auf Systemstandard setzen UTF-8

Sys.setlocale("LC_ALL", 'en_US.UTF-8') 

jedoch nicht auf Maschinen funktioniert, die diese locale nicht zur Verfügung haben:

1: Setting LC_CTYPE failed, using "C" 
2: Setting LC_COLLATE failed, using "C" 
3: Setting LC_TIME failed, using "C" 
4: Setting LC_MESSAGES failed, using "C" 
5: Setting LC_MONETARY failed, using “C” 

Gibt es eine Möglichkeit zu verwenden, Sys.setlocale um das Gebietsschema auf den Systemstandard UTF-8 einzustellen? I.e. etwas, das auch unter Windows oder einem deutschen Linux funktionieren würde?

+0

Haben Sie darüber nachgedacht, die Codierung für "extern" auf "UTF-8" zu setzen? –

+0

Ich bin mir nicht sicher, was du meinst – Jeroen

+0

Ich habe etwas falsch gelesen, was ich Anfang dieser Woche auf rdev gelesen habe. Vielleicht wird einer davon helfen: http://stackoverflow.com/questions/9387910/losing-locale-when-running-fcgi-script http://stackoverflow.com/questions/17985201/encoding-is-not-proper- when-query-from-apache-php/18079287 # 18079287 http://stackoverflow.com/questions/5674519/why-php-developers-cant-provide-setlocale-function-as-per-thread-scope –

Antwort

1

meine eigene Frage zu beantworten: Unter Ubuntu des Standard LANG in /etc/default/locale definiert:

[email protected]:~⟫ cat /etc/default/locale 
# Created by cloud-init v. 0.7.7 on Wed, 29 Jun 2016 11:02:51 +0000 
LANG="en_US.UTF-8" 

So in R wir so etwas wie tun könnten:

readRenviron("/etc/default/locale") 
LANG <- Sys.getenv("LANG") 
if(nchar(LANG)) 
    Sys.setlocale("LC_ALL", LANG) 

Apache hat auch eine Linie in /etc/apache2/envvars, die unkommentiert werden können, um dies zu ermöglichen.

2

Versuchen Sie folgendes:

Sys.setlocale(category = "LC_ALL", locale = "English_United States.1252") 
+0

Das funktioniert nur auf Windows? – Jeroen

+0

Ja, das ist richtig. Ich habe es nur unter Windows 7, 64 Bit getestet. Ich bin nicht sicher über Linux-Versionen, aber ich erinnere mich, sobald ich dieses Problem auf Ubuntu hatte, und ich folgte den Anweisungen auf diesem Link, um meine Gebietsschema-Einstellungen zu ändern. http://askubuntu.com/questions/162391/how-do-i-fix-my-locale-issue. Bitte zitieren Sie mich nicht für Linux-Versionen, da ich mir nicht sicher bin. – Sathish

+1

Ich habe das gerade auf meinem Ubuntu-Rechner getestet. Ich folgte dem Link in meinem vorherigen Kommentar. Dann eröffnete ich eine frische "R" -Sitzung. Die Gebietsschemaeinstellungen wurden automatisch in en_US.UTF8 geändert. Wenn Sie zum Typ "C" oder "POSIX" zurückkehren möchten, verwenden Sie die Funktion: Sys.setlocale (category = "LC_ALL", locale = "C"). HTH – Sathish

1

Ich denke, Sie brauchen einen Scheck für das Betriebssystem zu machen. Die Ländereinstellungen unterscheiden sich je nach Betriebssystem, siehe Beispiele in der Hilfedatei.

?Sys.getlocale() 

Examples 

Sys.getlocale() 
Sys.getlocale("LC_TIME") 
## Not run: 
Sys.setlocale("LC_TIME", "de")  # Solaris: details are OS-dependent 
Sys.setlocale("LC_TIME", "de_DE.utf8") # Modern Linux etc. 
Sys.setlocale("LC_TIME", "de_DE.UTF-8") # ditto 
Sys.setlocale("LC_TIME", "de_DE") # OS X, in UTF-8 
Sys.setlocale("LC_TIME", "German") # Windows 

## End(Not run) 
Sys.getlocale("LC_PAPER")   # may or may not be set 

## Not run: 
Sys.setlocale("LC_COLLATE", "C") # turn off locale-specific sorting, 
            # usually, but not on all platforms 
## End(Not run)