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

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

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

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

359閲覧

csファイル(エクセルで作ったもの)にutf8-4byte文字(例えば、 ???? )を表示させる方法を教えて下さい。

siosenbei

総合スコア22

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2018/03/05 10:58

表題のとおりです。

私のエクセル(エクセル2016)では、??となってしまします。
utf8-4byte文字はそもそも、sjis系の文字コードで取り扱うことは可能でしょうか?
扱えるなら、それを表示させる方法をご教示ください。

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

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

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

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

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

guest

回答3

0

ベストアンサー

すでにShift-JISで保存されたCSVファイルであればだめですが
今後Excel2016でCSV作成する場合、UTF-8で保存できるそうです。
参考:ExcelファイルをUTF-8のCSV形式で保存する方法(Excel 2016最新機能)

またUTF-8BOM付で保存されたCSVファイルであれば、Excel2010でも「????」は表示されました。
(BOMなしだと文字化けする)

追記

  • 文字「????」をShift_JIS-2004エンコードしてファイル保存
  • 文字「????」を含むShift_JIS-2004エンコードされたテキストファイルを読込み「????」を表示

であれば、Python(jupyter-notebook)上でできます。

Python

1enc = 'sjis_2004' 2 3# Unicode : U+2000B 4# UTF-8 : F0 A0 80 8B 5# JIS X0213:2004 : 87 A0 6print('????') 7print('????'.encode(enc)) # b'\x87\xa0' 8 9path = enc + '.txt' 10# 「Shift_JIS-2004」でエンコードしてファイル出力 11with open( path, 'w', encoding=enc) as f: 12 f.write('????') 13 14# バイナリとして開き、正しくエンコードされていることを確認 15with open( path, 'rb') as f: 16 print( f.read()) # b'\x87\xa0' 17 18# 「Shift_JIS-2004」でエンコードされたファイルを読込、正しく表示できることを確認 19with open( path, 'r', encoding=enc) as f: 20 print( f.read()) # ????

なおShift_JIS-2004に対応したテキストエディタを探してみましたが、見つかりませんでした。
Shift_JIS-2004に対応しているソフト、システムは少ないようですので、UNICODE(UTF-8)で扱うように運用を見直した方がよいかと思います。
参考:日立ミドルウェアの JIS X0213:2004 対応について- WindowsにおけるJIS X0213:2004対応 -

投稿2018/03/06 01:49

編集2018/03/09 04:05
can110

総合スコア38262

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

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

siosenbei

2018/03/09 01:26

ご回答、ありがとうございます。 そのcsvファイルを取り扱うシステムは、csvの文字コードをsjis-win(cp932)と定義ているため、 utf8-4byte文字がsjis-win(cp932)でのみ保存可能な場合は、考慮する必要がないのです。 下記によると、Shift_JIS-2004でコードの割当がされているので、 扱えるソフトウェアがあるのでは、と思っております。 https://ah-2.com/2015/09/18/sjis2004_utf8_4byte_chars.html もし、utf8-4byteに相当する文字がシステムに入った場合、 DB(Mysql)登録(InsertやUpdate)時にそれ以降の文字が消えてしまう問題が発生します。 それを防ぐため、 utf8-4byteをcsvとしてファイルに保存できる方法を探しております。
can110

2018/03/09 02:54

あげられている「システム」含め、背景、状況が良く分かりません。 ようするに > utf8-4byteをcsvとしてファイルに保存できる方法を探しております。 すなわち、文字「????」を「Shift_JIS-2004」エンコードしてファイル保存したい? あるいは 文字「????」を含む「Shift_JIS-2004」エンコードされたファイルを読込み、「????」として表示したい。 という要求(そういうソフトウェアなりシステムはないか?)でしょうか?
guest

0

ShiftJISコードセットにはその文字は無いようなので、それで取り扱うのは無理でしょうね

#丈ならあるんだけど

投稿2018/03/06 01:16

y_waiwai

総合スコア87749

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

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

y_waiwai

2018/03/09 01:28

UnicodeとJISでは一対一の対応は取れません。 まあ、数字とかアルファベットはどちらも順番に並んでいるので、機械的な変換はできるんですが、漢字の場合はバラバラです(一文字づつの変換テーブルが必要)、なので、後付けでJISに追加されたといっても、それが使えるとは限りません。(もちろんOSのメーカがそれに対応すれば使えますが) すくなくとも、Windows10Homeでは(今の段階では)JISにしても表示できていませんねー
y_waiwai

2018/03/09 01:44

ああ、そのCSVファイルを取り扱うシステム、というのがその追加されたJISコードを表示できる(取り扱うことができる)というなら、その追加された文字コードだけでも、自前で変換してしまう、というテもありかとおもいます。 が、Windows機では表示できないのでそこらへんをどうするかですねー 表示アプリを自前で用意するなら、これまたUnicodeへの変換を自前で用意すればいけるでしょうけどね
guest

0

csvファイルであれば、Excelではなく一旦、文字コード変更可能なテキストエディタ(秀丸など)で開いて、文字コードUTF-8形式(BOMあり)で保存しなおされたらどうでしょうか。
BOMが付いているcsvファイルであれば、ExcelもUTF-8形式として読み込んでくれるので文字化けは解消します。

投稿2018/03/06 08:35

編集2018/03/06 08:40
corporal_cregg

総合スコア14

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

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

siosenbei

2018/03/09 01:26

ご回答、ありがとうございます。 そのcsvファイルを取り扱うシステムは、csvの文字コードをsjis-win(cp932)と定義ているため、 utf8-4byte文字がsjis-win(cp932)でのみ保存可能な場合は、考慮する必要がないのです。 下記によると、Shift_JIS-2004でコードの割当がされているので、 扱えるソフトウェアがあるのでは、と思っております。 https://ah-2.com/2015/09/18/sjis2004_utf8_4byte_chars.html もし、utf8-4byteに相当する文字がシステムに入った場合、 DB(Mysql)登録(InsertやUpdate)時にそれ以降の文字が消えてしまう問題が発生します。 それを防ぐため、 utf8-4byteをcsvとしてファイルに保存できる方法を探しております。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問