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

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

ただいまの
回答率

87.79%

Python unicodeエラー?

解決済

回答 6

投稿

  • 評価
  • クリップ 0
  • VIEW 1,146

score 6

前提・実現したいこと

あるフォルダにあるxlsxファイルを開き中身を一部表示したい。

発生している問題・エラーメッセージ

(unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape (<unknown>, line 5)

該当のソースコード

import pathlib
import openpyxl
import csv

path=pathlib.Path("C:\Users\(ユーザー名)\Desktop")
for pass_obj in path.iterdir():
    if pass_obj.match("*.xlsx"):
        wb=openpyxl.load_workbook(pass_obj)
        for sh in wb:
            for dt_row in range(1,10):
                print(sh.cell(dt_row,1).value)

試したこと

Python3 Unicodeエラーでググってみましたが、Pythonではエンコード、デコードで問題が発生しやすいらしいということくらいしか分かりませんでした。

補足情報(FW/ツールのバージョンなど)

Visual Studio Code

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • meg_

    2020/05/19 15:12

    「path=pathlib.Path("C:\Users\(ユーザー名)\Desktop")」ですか?

    キャンセル

  • uppi

    2020/05/19 15:21

    そうです。その行のCのところに波線がはいって、上記のエラーがでます。

    キャンセル

  • quickquip

    2020/05/19 21:59

    Pythonをどうインストールしたのか、どう実行しているか書きましょう。

    コマンドで実行しているなら
    python -c 'import sys; print(sys.getdefaultencoding())'

    の、Visual Studio Codeで実行しているなら

    import sys
    print(sys.getdefaultencoding())

    の実行結果を書くといいかと思います。

    キャンセル

回答 6

check解決した方法

0

皆さんさまざまな回答ありがとうございました。
結局、何が原因なのかよくわからなかったのですが、もう一度、一から書き直してみると、なんと動きました。こういう解決のしかたは為にならないのは重々承知の上なのですが、現時点をもって解決ということにしたいと思います。
経験者からの意見にはたくさんの学びがありました。感謝しています。
下記に、コードを掲載します。

import pathlib
import openpyxl

path = pathlib.Path(r"C:\Users\(ユーザー名:英語)\Desktop")
for pass_obj in path.iterdir():
    if pass_obj.match("*.xlsx"):
        wb=openpyxl.load_workbook(pass_obj)
        for sh in wb:
            for dt_row in range(1,10):
                content=str(sh.cell(dt_row,1).value)
                print(content)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

そのファイルはテキストじゃないのでそのままでは表示できません
文字としても解釈不能なので、そのエラーが出てますね

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

ユーザー名に日本語などが入ってませんか?

path=pathlib.Path(r"C:\Users\(ユーザー名)\Desktop")


で試してみてください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/05/19 16:14

    だとすると、(ユーザー名)を変えて試すとどうなりますかね?

    キャンセル

  • 2020/05/19 16:16

    あ、ユーザ名は変えられないので、ディレクトリを変えて試してみるしか無いですが。

    キャンセル

  • 2020/05/19 21:38

    例えばですが、r"..\data"などの他のファイルパスでも同じでした。

    キャンセル

0

path=pathlib.Path("C:\Users\(ユーザー名)\Desktop")\\\/に変更しましょう。


【NGの場合】
path = pathlib.Path("C:\Users\a\Desktop")
File "<stdin>", line 1
SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in positio
n 2-3: truncated \UXXXXXXXX escape

【OKの場合】
path = pathlib.Path("C:\\Users\\a\\Desktop")
path = pathlib.Path("C:/Users/a/Desktop")

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/05/19 15:47

    そうです。どのパターンでも同じエラーでした。
    パスの頭にrやuを入れても同じです。
    実行環境はwindowsです。そういうのも入れるべきでしたね。すいません。
    visual studio codeで皆さんと違うのは、日本語化していないことかもしれません。どうせエラーとか英語版の直訳になるんだったら分かりにくいかと思い、インストール後の英語のまま使っています。

    キャンセル

  • 2020/05/19 15:52

    /(スラッシュ)でも駄目でしたか。

    キャンセル

  • 2020/05/19 16:05

    はい。ダメでした。

    キャンセル

0

print (u"表示させたい文字")
でUnicode出力ができるはずです

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/05/19 15:35

    回答ありがとうございます。
    確かにプリント関数を使うときに必要になるかもしれません。
    しかし、今は5行目の
    path=pathlib.Path("C:\Users\(ユーザー名)\Desktop")
    のCの部分にUnicodeエラーがでて困っています。

    キャンセル

  • 2020/05/19 20:04

    windowsですか?それ以外ですか?

    キャンセル

  • 2020/05/19 20:05

    "C:\\Users ……
    として書いてみては?

    キャンセル

  • 2020/05/19 20:09

    すいません。もう出てました。

    キャンセル

0

python script の encoding は何になっていますか?
utf-8 以外の場合、1行目に(例えば cp932 なら) 次のような行をいれてみてください。

# coding: cp932

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 87.79%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る