【问题标题】:Can't start python script in Android Studio via Chaquopy after including dateparser包含 dateparser 后无法通过 Chaquopy 在 Android Studio 中启动 python 脚本
【发布时间】:2020-08-25 08:30:57
【问题描述】:

我正在尝试使用 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' 对象没有属性 '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)

【问题讨论】:

  • 非常感谢@mhsmith 提供的信息,它帮助了我很多。我不再使用该库,因此删除该库解决了我的问题(希望在进一步的实现中不需要它)。我还删除了 geograpy,因为这也是一个问题。我必须删除的另一个库是 googleapiclient,现在我将在 android 端传输数据并在那里使用它。如果您能找到解决方法,我仍然很感兴趣。

标签: python android android-studio kotlin chaquopy


【解决方案1】:

看起来 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,我不知道该软件包有任何问题,因此请在单独的问题中提供详细信息,或者最好在 our GitHub page 上创建问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-07-20
    • 2020-07-17
    • 1970-01-01
    • 1970-01-01
    • 2020-11-03
    • 1970-01-01
    • 1970-01-01
    • 2021-06-22
    相关资源
    最近更新 更多