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

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

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

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

1242閲覧

Python3 win32com xlsx pdf変換でエラーが発生する

person

総合スコア223

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2023/05/12 01:28

編集2023/05/30 22:04

実現したいこと

xlsxファイルをpdfに変換したいです。
実装には、記載のコードを使えば一応変換できます。
ただ、別のブックを開いていてその数式バーがアクティブになっているとAttributeErrorが発生してしまいます。

Excelを開きながら、この機能をpythonで使いたいので、
「ブックを閉じればエラーが発生しない」以外で解決策があれば教えてください。

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

Traceback (most recent call last): File "c:/Users/user01/Desktop/a.py", line 10, in <module> wb = excel.Workbooks.Open(xlsx) File "C:\Users\user01\AppData\Local\Programs\Python\Python38-32\lib\site-packages\win32com\client\dynamic.py", line 639, in __getattr__ raise AttributeError("%s.%s" % (self._username_, attr)) AttributeError: Excel.Application.Workbooks

該当のソースコード

Python3

1from win32com.client import Dispatch 2from win32com.client.gencache import EnsureDispatch 3 4 5excel = Dispatch("Excel.Application") 6#excel = EnsureDispatch("Excel.Application") 7 8xlsx = r"C:\Users\user01\Desktop\Book.xlsx" 9pdf = r"C:\Users\user01\Desktop\Book.pdf" 10 11wb = excel.Workbooks.Open(xlsx) 12#wb.WorkSheets(1).Select() 13wb.Worksheets(1).Select() 14wb.ActiveSheet.ExportAsFixedFormat(0, pdf) 15wb.Close()

試したこと

下記サイトにあった質問の回答の中で、DispatchではなくEnsureDispatchがありそれを使うようなものがあった。
試したが下記エラー発生。

エラー

Traceback (most recent call last): File "C:\Users\user01\AppData\Local\Programs\Python\Python38-32\lib\site-packages\win32com\client\gencache.py", line 621, in EnsureDispatch ti = disp._oleobj_.GetTypeInfo() pywintypes.com_error: (-2147418111, '呼び出し先が呼び出しを拒否しました。', None, None) During handling of the above exception, another exception occurred: Traceback (most recent call last): File "c:/Users/user01/Desktop/a.py", line 5, in <module> excel = EnsureDispatch("Excel.Application") File "C:\Users\user01\AppData\Local\Programs\Python\Python38-32\lib\site-packages\win32com\client\gencache.py", line 633, in EnsureDispatch raise TypeError( TypeError: This COM object can not automate the makepy process - please run makepy manually for this object

参考
stackoverflow win32com Excel.Application can't open documents anymore

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

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

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

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

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

otn

2023/05/12 05:55 編集

おそらくExcelを新規インスタンスで起動できれば解決しそうに覆いますが、 コマンドライン起動時の情報はありますが、他のプログラムからExcel別インスタンス起動については、あまり情報が無いですね(私も知りません)。
Bull

2023/05/12 08:50

別インスタンスでエクセルを起動すれば、数式バーがアクティブでも問題ないようです。 PowerShell や C++ (おそらく C# でも) ならば、別インスタンスでエクセルを起動できるようですが、Python の win32com では、検索しましたがちょっと見付かりませんでした。
Bull

2023/05/19 07:20

別件で win32com を調べていて偶然に見つけました。 "DispatchEx" を使用すれば、エクセルがすでに起動していても別インスタンスで起動します。 ドキュメントは見付からなかったのですが "Dispatch" を単純に "DispatchEx" に置換えるだけで使えるようです。 簡単にテストしてみましたが、数式バーがアクティブになっていても PDF にできています。
person

2023/05/29 07:15

回答の確認が遅れてしまい申し訳ありません。 こちらでも確認してみます。
person

2023/05/30 03:40

確認しました。こちらの環境でも、PDF化できました。 ベストアンサーにしたいので、回答として投稿していただきたいのですが可能ですか?
guest

回答1

0

ベストアンサー

Excelを別インスタンスで起動すると、数式バーがアクティブになっていてもPythonから操作が可能になりワークブックをPDF化することができます。
Excelを別インスタンスで起動するには、Dispatchの代わりにDispatchExを使用します。

投稿2023/05/30 13:04

Bull

総合スコア986

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.51%

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

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

質問する

関連した質問