python – 在django中运行PyUNO

我有一个运行SUSE Enterprise Server 11的客户,我想在其上使用名为PyUNO的OpenOffice-
Python-Bridge的django项目.它使用mod_wsgi运行apache2,并且没有virtualenv或其他东西.

我添加了PYTHONPATH的相关路径,但是当我运行shell python manage.py shell并尝试导入uno时,我收到此错误:

dynamic module not initialized properly

它是OpenOffice 3.4,python 2.6.x(均来自SUSE-DVD).

谷歌引导我进入一个系统变量LD_LIBRARY_PATH,但是一旦我设置它,我就不能再启动shell了,因为python再也找不到django了(PYTHONPATH似乎以某种方式被破坏了).如果我运行ldconfig -v / path / to / openoffice / program /这是另一个常见的提议,结果是一样的.

执行上述操作之一后,我可以运行系统范围的python并导入uno.但我不能再运行django-shell了,因为找不到django.

如果我重置LD_LIBRARY_PATH(通过unset LD_LIBRARY_PATH或ldconfig),我会进入“旧”状态.

OpenOffice捆绑了一个python-binary.这个可以导入uno没有错误.

结果:
我想过使用另一个uno.py或以某种方式告诉apache2使用openoffice附带的python-version.我该怎么做这样的事情或者将相关的pyuno-dependencies添加到apache使用的python-version中?或者哪个版本的openoffice / pyuno可以解决我的问题?我想避免从SUSE-sources接触mod_wsgi和python.

另外一些关于LD_LIBRARY_PATH的提示可能会有所帮助.

最佳答案 LD_LIBRARY_PATH是一个覆盖共享库(通常为.so)的搜索路径的变量.

例如,当您设置它时,导出LD_LIBRARY_PATH = / opt / test / mylibs可以使所有应用程序在该位置搜索共享库.

这解释了为什么django-shell无法运行,因为它正在搜索不存在的库.

好消息是LD_LIBRARY_PATH可以设置为几个路径,用冒号(:)分隔.这样,您可以导出LD_LIBRARY_PATH = / opt / test / mylibs:/ opt / another / path

如果您设法找到所需的所有库所在的位置,则可以将其路径附加到LD_LIBRARY_PATH,这可能足以解决您的问题.

我不知道,不管这是你面临的真正问题,但我认为这可能会让你对这个变量的意义有所了解.

点赞