- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我写了一个小的 python 脚本来解析/提取 PDF 中的信息。我在我的本地机器上测试了它,我有 python 2.6.2 和 pdftotext 版本 0.12.4。
我正在尝试在我的虚拟主机服务器 (dreamhost) 上运行它。它有 python 版本 2.5.2 和 pdftotext 版本 3.02。
但是当我尝试运行脚本时,我在 pdftotext 行收到以下错误(我也使用简单的丢弃脚本对其进行了检查)“错误:无法打开文件 '-'”
def ConvertPDFToText(currentPDF):
pdfData = currentPDF.read()
tf = os.tmpfile()
tf.write(pdfData)
tf.seek(0)
if (len(pdfData) > 0) :
out, err = subprocess.Popen(["pdftotext", "-layout", "-", "-"], stdin = tf, stdout=subprocess.PIPE ).communicate()
return out
else :
return None
请注意,我向此函数传递了同一个 PDF 文件,它确实可以访问它。在另一个功能中,我可以通过在网络主机上运行的相同脚本将 PDF 文档通过电子邮件发送给自己。
我做错了什么?我的本地版本和 webhost 版本在 subprocess/python/pdftext 的使用上可能有什么不同?我猜我将不得不修改命令,因此我们将不胜感激任何帮助。
提前致谢。
最佳答案
答案的提示在 Noufal 的评论中,使用文件名。但是 os.tmpfile() 没有文件名。我不得不使用另一个模块。修改后的代码如下。
#import tempfile
def ConvertPDFToText(currentPDF):
pdfData = currentPDF.read()
tf = tempfile.NamedTemporaryFile()
tf.write(pdfData)
tf.seek(0)
outputTf = tempfile.NamedTemporaryFile()
if (len(pdfData) > 0) :
out, err = subprocess.Popen(["pdftotext", "-layout", tf.name, outputTf.name ]).communicate()
return outputTf.read()
else :
return None
不过,我不确定如何为 Noufal 的评论提供此答案的要点。也许他可以剪切并粘贴这个答案?
关于python - 当我从本地计算机更改为我的虚拟主机时,从 python 脚本调用 pdftotext 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4837114/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!