包含dateparser后,无法通过Chaquopy在Android Studio中启动python脚本

问题描述

我正在尝试使用Kotlin在Android Studio中通过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()
    }

在调试期间,我已经通过grapip(app)文件中的pip包含了所有必需的库(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)

解决方法

看起来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不兼容。它具有一些最新的fork,您可以尝试。

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