実現したいこと
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
おそらくExcelを新規インスタンスで起動できれば解決しそうに覆いますが、
コマンドライン起動時の情報はありますが、他のプログラムからExcel別インスタンス起動については、あまり情報が無いですね(私も知りません)。
別インスタンスでエクセルを起動すれば、数式バーがアクティブでも問題ないようです。
PowerShell や C++ (おそらく C# でも) ならば、別インスタンスでエクセルを起動できるようですが、Python の win32com では、検索しましたがちょっと見付かりませんでした。
別件で win32com を調べていて偶然に見つけました。
"DispatchEx" を使用すれば、エクセルがすでに起動していても別インスタンスで起動します。
ドキュメントは見付からなかったのですが "Dispatch" を単純に "DispatchEx" に置換えるだけで使えるようです。
簡単にテストしてみましたが、数式バーがアクティブになっていても PDF にできています。
回答の確認が遅れてしまい申し訳ありません。
こちらでも確認してみます。
確認しました。こちらの環境でも、PDF化できました。
ベストアンサーにしたいので、回答として投稿していただきたいのですが可能ですか?

回答1件
あなたの回答
tips
プレビュー