質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Gunicorn

Gunicorn (Green Unicorn)は、Rubyのunicornをベースに開発されたUNIX向けのPython製HTTPサーバです。他のライブラリとの依存関係がないため、容易にインストールして使用できます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

2406閲覧

アイウエオ順に並べる方法

退会済みユーザー

退会済みユーザー

総合スコア0

Gunicorn

Gunicorn (Green Unicorn)は、Rubyのunicornをベースに開発されたUNIX向けのPython製HTTPサーバです。他のライブラリとの依存関係がないため、容易にインストールして使用できます。

Django

DjangoはPythonで書かれた、オープンソースウェブアプリケーションのフレームワークです。複雑なデータベースを扱うウェブサイトを開発する際に必要な労力を減らす為にデザインされました。

nginx

nginixは軽量で高性能なwebサーバーの1つです。BSD-likeライセンスのもとリリースされており、あわせてHTTPサーバ、リバースプロキシ、メールプロキシの機能も備えています。MacOSX、Windows、Linux、上で動作します。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

3グッド

3クリップ

投稿2017/03/26 14:15

編集2017/03/26 14:16

Django(Python)でwebサイトを作成しています。

開発環境:
Ubuntu 16.04.2 LTS
python manage.py runserverでサーバーを起動しています。

本番環境:
SakuraVPS上で、Ubuntu 16.04.1 LTSを動かしています。
Gunicorn + nginxで動かしています。

下記のような都道府県名のデータベースがあり、それをアイウエオ順に表示したいと思っています。

namephonetic
東京とうきょう
神奈川かながわ
千葉ちば
その他

コードは下記のとおりです。

python

1# views.py 2def test(request): 3 prefecture = Prefecture.objects.order_by( 4 'phonetic' 5 ) 6 context = { 7 'prefecture': prefecture, 8 } 9 return render(request, 'test/test.html', context)

html

1<!--test.html(レンダリングするテンプレート)--> 2{% for pref in prefecture %} 3 {{pref}} 4{% endfor %}

上記のようにしているのですが、開発環境と本番環境とで挙動が違います。
開発環境ではこちらの狙い通りアイウエオ順で並ぶのですが、本番環境ではそうなりません。

Gunicorn+nginxでは、日本語の取り扱いが違うのでしょうか。
アイウエオ順に並べる方法がお分かりの方、ご教示頂ければ幸いです。
よろしくお願いいたします。

av-, Youhei-Sakura, etetetetetetete👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

上記のコード見る限り、DjangoとPythonにはあまり問題があるように見えません。 可能性があるとすればDBの文字コード等の設定が開発と本番で違っているため、差異がでてしまっているのかもしれません。

試しに開発環境と本番環境のDBに入って直接order by するようなSQLを発行してみると良いと思います。

sql

1SELECT * FROM prefetcure ORDER BY phonetic;

過去に似たような質問もあったので参考までに貼っておきます。この方はPostgreSQLを利用してたようです。

Python DjangoをAWSで動かした際のorder_byの挙動

投稿2017/03/26 14:27

編集2017/03/26 15:27
tell_k

総合スコア2120

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/03/29 15:06

ご回答頂き、ありがとうございます。返事が遅れて申し訳ありません。 大事なことを伝え忘れていました。 開発環境では、sqlite3 本番環境では、postgresqlを利用しています。 SELECT * FROM prefetcure ORDER BY phonetic; を実行すると、 ERROR: character with byte sequence 0xe3 0x81 0x9d in encoding "UTF8" has no equivalent in encoding "LATIN1" となり、そもそも上記コマンドが実行できませんでした。 なんとなくここに問題があるような気がするのですが、どうしたらいいかわからないです。
guest

0

Python のバージョンを確認してみてください。2 と 3 では文字列の扱いが異なりますし、2 の場合は環境によって異なるエンコードを使います。

追記

Pythonの日本語処理

Pythonでは,文字列は8ビット単位で格納され,その文字符号化はプラットフォームによって異なる. 文字列は次のように生成する. >>> s='日本語' >>> print s 日本語 なお,プラットフォームにより,変数sにどのような値が入っているかは異なる.例えば,Mac OS Xでは,この文字列はUTF-8で符号化され,文字列長は9バイトである. >>> s '\xe6\x97\xa5\xe6\x9c\xac\xe8\xaa\x9e' >>> len(s) 9 Windowsでは,CP 932で符号化され,文字列長は6バイトである. >>> s '\x93\xfa\x96{\x8c\xea' >>> len(s) 6

投稿2017/03/26 14:34

編集2017/03/26 14:59
Zuishin

総合スコア28660

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/03/29 14:13

ご回答いただき、ありがとうございます。両方共Python3です。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問