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

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

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

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

Q&A

解決済

2回答

2505閲覧

pyinstallerで作成したexeファイルが実行できない。

noharabu

総合スコア2

Python

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

0グッド

2クリップ

投稿2021/06/03 08:38

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

はじめて投稿します。
pyinstallerを用いてエラーなしでexeファイル作成できたのですが、実行できませんでした。
ログでは以下のエラーがひとつのみ出ています。

[13168] LOADER: Error activating the context: ActivateActCtx: 既定のアクティブ化コンテキストのプロセスは既に設定されていたため、既定のアクティブ化コンテキストのプロセスを設定する試み は失敗しました。

該当のソースコード

http://sin-to-meru.jugem.jp/?eid=13

Python

1# -*- coding:utf-8 -*- 2import os 3import glob 4import chardet 5 6def is_utf8_file_with_bom(filename): 7 '''utf-8 ファイルが BOM ありかどうかを判定する 8 ''' 9 line_first = codecs.open(filename, 'r', 'utf-8').readline() 10 return (line_first[0] == u'¥ufeff') 11 12def check_encoding(file_path): 13 """ファイルのエンコーディングを取得する。 14 Args: 15 file_path (string): ファイル名 16 Return: 17 string : エンコーディング 18 """ 19 detector = chardet.UniversalDetector() 20 with open(file_path, mode='rb') as f: 21 for binary in f: 22 detector.feed(binary) 23 if detector.done: 24 break 25 detector.close() 26 enc = detector.result['encoding'] 27 if enc == 'utf-8': 28 is_with_bom = is_utf8_file_with_bom(file_path) 29 enc = 'utf-8-sig' if is_with_bom else 'utf-8' 30 return enc 31 32def main(): 33 workDir = os.path.dirname(os.path.abspath(__file__)) 34 fileList = glob.glob(workDir + "/*.txt"); 35 outputDir = f'{workDir}/utf8' 36 if not os.path.exists(outputDir): 37 os.mkdir(outputDir) 38 for file in fileList: 39 enc = check_encoding(file) 40 if (enc == 'Windows-1252'): 41 enc = 'Shift-JIS' 42 print(f'file:{file} enc:{enc}') 43 baseName = os.path.basename(file) 44 utf8File = f'{outputDir}/{baseName}' 45 # 文字コードを utf-8 に変換して保存 46 with open(file, "r", encoding=enc) as orgFile, open(utf8File, "w", encoding="utf-8") as outFile: 47 data = orgFile.read() 48 outFile.write(data) 49 50if __name__ == '__main__': 51 main()

試したこと

exe化する前の.pyで実行したときは、chardetのImportができずに実行できませんでしたが、
コマンドプロンプトからは実行できました。
chardetをImportした.pyは問題なく実行できるのですが、exe化すると動きません。

補足情報

[13168] LOADER: Error activating the context: ActivateActCtx:
のエラーについての日本語の情報が少ないです。

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

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

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

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

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

jbpb0

2021/06/03 10:33

> ログでは以下のエラーがひとつのみ Traceback で始まる行はありませんか?
noharabu

2021/06/04 00:41

# traceback not found in PYZ がありました。ほかにも # chardet not found in PYZ もありました。 ライブラリがexeに含まれていないということですかね。
jbpb0

2021/06/04 02:34

https://github.com/pyinstaller/pyinstaller/issues/2495#issuecomment-286209531 の、Johndt6さんの14 Mar 2017のコメントの後半の長ーーーいのの途中に、 > LOADER: Error activating the context: ActivateActCtx: が出てきます ただし、そのずっと下の「Traceback」で始まる行は、質問者さんとは違いますので、質問者さんの現状と上記Webページに書かれてる現象が合致するかは分かりませんが、上記コメントのすぐ下のhtgoebelさんの14 Mar 2017のコメントに書かれてるようなことをやって調べたら、何か分かるかもしれません
guest

回答2

0

解決方法

まず今回作成したいプログラムはPythonで複数のテキストファイル内で文字列を検索するプログラムでした。
端末(Windows)の設定を出力したテキストファイル内を検索します。
先に挙げたソースコードはコマンドプロンプトで出力したテキストファイルの文字コードをutf-8に変換します。
その際にでたエラーでした。

エラーの理由がわからなかったためコマンドプロンプトから出力するバッチにchcp 65001を入れてutf-8で出力。
それでも一部のファイルはutf-16-BOM付のため以下のコードで文字コードを変換しました。

Python

1 2""" 3機能   :utf-16-leからutf-8-sigに変換 4 5引数   :filename - ファイル名 6""" 7def conversion2(filename): 8 # utf-16-le ファイルのパス 9 shiftjis_file_path = filename + '.txt' 10 # utf-8-sig ファイルのパス 11 utf8_file_path = filename + '_utf8.txt' 12 13 # 文字コードを utf-16-leからutf-8 に変換して保存 14 fin = codecs.open(shiftjis_file_path, "r", "utf-16-le") 15 fout_utf = codecs.open(utf8_file_path, "w", "utf-8") 16 for row in fin: 17 fout_utf.write(row) 18 fin.close() 19 fout_utf.close() 20  # 文字コードを utf-8-sigからutf-8 に変換して保存 21 s = open(filename + "_utf8.txt", mode='r', encoding='utf-8-sig') 22 m = s.read() 23 open(filename + "_utf8.txt", mode='w', encoding='utf-8').write(m) 24 return

これで全てのファイルの文字コードの変換ができました。
ちなみにですがこのコードで
utf-16-leからutf-8に変換、そしてutf-8-sigからutf-8 に変換しています。
普通に考えると
utf-16-leからutf-8-sigに変換、そしてutf-8-sigからutf-8 に変換が正しいと思いますが
これだとBOMが消えないです。なぜかはわかりません。

投稿2021/06/08 09:38

noharabu

総合スコア2

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

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

0

自己解決

コードを大きく変更し、別の方法で解決できました。
お答え下さりありがとうございました。

投稿2021/06/07 08:41

noharabu

総合スコア2

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

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

BeatStar

2021/06/07 08:47

それなら、『どのように解決したか』を書いた方がいいですよ。 質問者さんと同じような状況に陥った後続の人達のためにも書いておくべきです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問