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

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

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

PyInstallerは、Pythonのスクリプトを一括でWindowsなどで動く実行可能ファイルに変換できるツールです。このツールを用いることで自作のPythonプログラムを別で使用する場合でもPythonをインストールする必要がありません。

Python 3.x

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

Q&A

解決済

1回答

4551閲覧

RunFrozenPythonをxlwings公式ページの通りに動かしているが、VBA上で「コンパイルエラー」となる

H.K2

総合スコア88

PyInstaller

PyInstallerは、Pythonのスクリプトを一括でWindowsなどで動く実行可能ファイルに変換できるツールです。このツールを用いることで自作のPythonプログラムを別で使用する場合でもPythonをインストールする必要がありません。

Python 3.x

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

1グッド

0クリップ

投稿2020/03/14 11:48

編集2020/03/14 11:51

前提・実現したいこと

下記質問の続きとなります。
(下記は一応解決しましたので、関連はないと思いますが念のため。)
https://teratail.com/questions/247002

xlwingsで、Mysqlのデータを取り込んでexcelに出力するプログラムを作ろうとしています。openpyxlでは、既存のexcelシートの一部だけを上書きすることができなかったので、xlwingsで実現しようとしたのですが、配布用にexeが便利であるため、
公式で確認した、RunFrozenPythonの機能を用いて実現しようと思い試してみましたが、VBA側でエラーが出て解決できなくなってしまいました。
たびたびお手数をおかけし申し訳ありませんが、もしよろしければご回答いただけますと幸甚に存じます。

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

VBA側で「SubまたはFunctionが定義されていません」と出ます。 ※pyinstallerで作成した、exeは実行できることを確認しています。

ソースコード

python3

1from xlwings import Book 2import xlwings as xw 3 4def test(): 5 sh = xw.Book.caller().sheets['a'] 6 sh.range('A1').value = 'hello' 7 8 9if __name__ == '__main__': 10 test()

VBA

1Public Sub SampleCall() 2 Dim path, args As String 3 path = ThisWorkbook.path + "\generate_queries_to_VBA.exe" 4 args = "arg1 arg2" 5 MsgBox (path + "," + args) 6 RunFrozenPython path, args 7End Sub

試したこと

公式のxlwingsのページを調べて、類似の問題がないか確認
https://docs.xlwings.org/en/stable/deployment.html
など。
pythonソースコードの中身を色々変えたりしてみた。(空にしたりとか、main消してみたりとか)

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

仮想環境のライブラリの状況は下記となります。
altgraph 0.17 pypi_0 pypi
ca-certificates 2019.11.27 0
certifi 2019.11.28 py37_0
comtypes 1.1.7 pypi_0 pypi
et-xmlfile 1.0.1 pypi_0 pypi
future 0.18.2 pypi_0 pypi
jdcal 1.4.1 pypi_0 pypi
numpy 1.18.1 pypi_0 pypi
openpyxl 3.0.3 pypi_0 pypi
openssl 1.1.1d he774522_3
pandas 0.25.3 pypi_0 pypi
pefile 2019.4.18 pypi_0 pypi
pip 19.3.1 py37_0
pyinstaller 3.6 pypi_0 pypi
python 3.7.6 h60c2a47_2
python-dateutil 2.8.1 pypi_0 pypi
pytz 2019.3 pypi_0 pypi
pywin32 227 pypi_0 pypi
pywin32-ctypes 0.2.0 pypi_0 pypi
setuptools 44.0.0 py37_0
six 1.14.0 pypi_0 pypi
sqlalchemy 1.3.15 pypi_0 pypi
sqlite 3.30.1 he774522_0
vc 14.1 h0510ff6_4
vs2015_runtime 14.16.27012 hf0eaf9b_1
wheel 0.33.6 py37_0
wincertstore 0.2 py37_0
xlwings 0.18.0 pypi_0 pypi

s.k👍を押しています

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

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

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

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

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

guest

回答1

0

自己解決

自己解決しました。
下記サイトに記載のように,VBエディタ側で、xlwingsを関連付けることで対応できました。

https://qiita.com/yniji/items/b38bc312e860027108ac

メニューから[開発]->[Visual Basic]で、Visual Basic for Application のエディターを立ち上げます。そこのメニューから[ツール]->[参照設定]を選択すると以下のようなダイアログが表示されるので、xlwings にチェックをして参照設定をします。

また、pycharmで、runpythonのデバッグをする場合は、xlwingsのメニューから、runpythonと、デバッグのチェックを入れることで、pycharm上からデバッグできることを確認しました。(exeではなく、普通のpyファイルの場合)

投稿2020/03/20 14:07

H.K2

総合スコア88

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問