3

我正在尝试通过带有 kotlin 的 Android 工作室中的 chaquopy 插件启动我的 python 脚本。

这是我通过 Kotlin 启动 python 脚本的方式

    private fun getPythonHello(): String {
        if (! Python.isStarted()) {
            Python.start(AndroidPlatform(this));
        }
        val python = Python.getInstance()
        val pythonFile = python.getModule("edit_package_data_to_application")
        return pythonFile.callAttr("main").toString()
    }

在调试期间,我已经通过 pip 在 gradle(app) 文件中包含了所有必需的库(nltk、scitkit 等)。包含所有库后出现此错误:“AttributeError: 'zipimporter' object has no attribute 'exec_module'”

有谁知道为什么会出现这个错误?

2020-08-25 16:41:32.538 12129-12129/com.pro.useyournotes E/ExceptionTag: com.chaquo.python.PyException: AttributeError: 'zipimporter' object has no attribute 'exec_module'
    com.chaquo.python.PyException: AttributeError: 'zipimporter' object has no attribute 'exec_module'
        at <python>.dateparser.utils.strptime.patch_strptime(strptime.py:40)
        at <python>.dateparser.utils.strptime.<module>(strptime.py:69)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.dateparser.parser.<module>(parser.py:12)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.dateparser.date_parser.<module>(date_parser.py:11)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.dateparser.date.<module>(date.py:12)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.dateparser.<module>(__init__.py:4)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.functionalities_pre_processing.<module>(functionalities_pre_processing.py:22)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.main_useyournotes_analysis.<module>(main_useyournotes_analysis.py:7)
        at <python>.java.chaquopy.import_override(import.pxi:26)
        at <python>.edit_package_data_to_application.<module>(edit_package_data_to_application.py:14)
        at <python>.importlib._bootstrap._call_with_frames_removed(<frozen importlib._bootstrap>:219)
        at <python>.importlib._bootstrap_external.exec_module(<frozen importlib._bootstrap_external>:783)
        at <python>.java.android.importer.exec_module(importer.py:477)
        at <python>.importlib._bootstrap._load_unlocked(<frozen importlib._bootstrap>:671)
        at <python>.importlib._bootstrap._find_and_load_unlocked(<frozen importlib._bootstrap>:975)
        at <python>.importlib._bootstrap._find_and_load(<frozen importlib._bootstrap>:991)
        at <python>.importlib._bootstrap._gcd_import(<frozen importlib._bootstrap>:1014)
        at <python>.importlib.import_module(__init__.py:127)
        at <python>.chaquopy_java.Java_com_chaquo_python_Python_getModule(chaquopy_java.pyx:153)
        at com.chaquo.python.Python.getModule(Native Method)
        at com.pro.useyournotes.MainActivity.getPythonHello(MainActivity.kt:69)
        at com.pro.useyournotes.MainActivity.onCreate(MainActivity.kt:59)
        at android.app.Activity.performCreate(Activity.java:7136)
        at android.app.Activity.performCreate(Activity.java:7127)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1271)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2893)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3048)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:78)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:108)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:68)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1808)
        at android.os.Handler.dispatchMessage(Handler.java:106)
        at android.os.Looper.loop(Looper.java:193)
        at android.app.ActivityThread.main(ActivityThread.java:6669)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:858)
4

1 回答 1

0

看起来 dateparser 假定标准库模块是由支持新导入器 API 的加载器加载的。不幸的是,Chaquopy 使用 zipimporter 加载标准库,尽管它是标准库本身的一部分,但仍然没有实现新的 API。

此问题已在 Chaquopy 9.0.0 中修复。对于旧版本,您可以通过在导入 dateparser 之前运行以下代码来解决它:

from zipimport import zipimporter

def create_module(self, spec):
    return None
zipimporter.create_module = create_module

def exec_module(self, module):
    exec(self.get_code(module.__name__), module.__dict__)
zipimporter.exec_module = exec_module

我还删除了 geograpy,因为这也是一个问题。我必须删除的另一个库是googleapiclient,现在我将在 android 端传输数据并在那里使用它。

geograpy 似乎是一个与 Python 3 不兼容的废弃库。它有一些更新的分支,您可以尝试。

至于 googleapiclient,我不知道该软件包有任何问题,因此请在单独的问题中提供详细信息,或者最好在我们的 GitHub 页面上创建问题。

于 2020-08-26T19:20:01.140 回答