Navigation

Related Articles

Back to Latest Articles

DjangoでダウンロードするCSVの文字コードを設定


press
DjangoでダウンロードするCSVの文字コードを設定

以下のような、attachmentをつけて即ダウンロードが始まるシステムで、文字コードをShift-JISにする為にto_csv()の引数にencodingをShift-JISに設定しても、ダウンロードするとUTF-8でダウンロードされてしまいました。
他にもencodingをcp923に設定してダウンロードしてみましたが、同じくUTF-8でダウンロードされてしまいました。

    file_name = 'filename.csv'

    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment; filename="{}"'.format(urllib.parse.quote(file_name))

    df.to_csv(path_or_buf=response, sep=';', float_format='%.2f', index=True, decimal=",", encoding='shift_jis')

    return response

調べていて分かったことは、to_csv()のencodingをShift-JISに設定するのではなく、HttpResponse自体のcharsetをShift-JISに設定してあげると無事にダウンロードできるということ。

    file_name = 'filename.csv'

    response = HttpResponse(content_type='text/csv; charset=Shift-JIS')
    response['Content-Disposition'] = 'attachment; filename="{}"'.format(urllib.parse.quote(file_name))

    df.to_csv(path_or_buf=response, sep=';', float_format='%.2f', index=True, decimal=",", encoding='shift_jis')

    return response

response = HttpResponse(content_type='text/csv; charset=Shift-JIS')
charsetをShift-JISに設定


当ブログは群馬県でPython / Djangoを中心にウェブアプリケーションを開発している株式会社ファントムが運営しています。

株式会社ファントムへのお問い合わせ




    Show Comments (0)

    Comments

    Related Articles

    Django

    Djangoで日本語文字列のQuerySetを五十音順でソートする

    DjangoのWEBアプリケーションでQuerySetの表示順を五十音順にしたら、開発環境では五十音順で表示されているのに本番環境では五十音順になっていないときの対処法です。(中途半端に五十音順になっていて、4、5件毎に […]

    Posted on by press
    Django

    Djangoでマイグレーションをやり直す

    Djangoでマイグレーションをやり直す Djangoで開発中にマイグレーションを元に戻したり(ロールバック)、やり直したくなった時の方法です。部分的に戻す方法と初期化したい方法の2パターンを紹介します。 開発環境 まず […]

    Posted on by press