ClassFormatError:无效方法类文件中的代码长度为85551 pdfminer / glyphlist $ py

时间:2015-06-16 07:43:00

标签: python robotframework

我正在从命令行运行验收测试,它在内部调用pdfminer python脚本方法将Pdf转换为Text。我提供了PDF2TextLibrary,其中包含使用pdfminer库将Pdf转换为文本的代码。

但是当我运行测试时,我得到了错误:

ClassFormatError: Invalid method Code length 85551 in class file pdfminer/glyphlist$py

2 个答案:

答案 0 :(得分:0)

如果您只使用一种功能,我认为您不需要上课。您可以保存代码并使其更易于阅读:

pdf2text.py

from pdfminer.pdfinterp import PDFResourceManager, PDFPageInterpreter
from pdfminer.converter import TextConverter
from pdfminer.layout import LAParams
from pdfminer.pdfpage import PDFPage
from cStringIO import StringIO


def convert_pdf_to_txt(path):
    rsrcmgr = PDFResourceManager()
    retstr = StringIO()
    codec = 'utf-8'
    laparams = LAParams()
    device = TextConverter(rsrcmgr, retstr, codec=codec, laparams=laparams)
    fp = file(path, 'rb')
    interpreter = PDFPageInterpreter(rsrcmgr, device)
    password = ""
    maxpages = 0
    caching = True
    pagenos=set()
    for page in PDFPage.get_pages(fp, pagenos, maxpages=maxpages, password=password,caching=caching, check_extractable=True):
        interpreter.process_page(page)
    fp.close()
    device.close()
    textstr = retstr.getvalue()
    retstr.close()
    return textstr

这就是我使用它的方式:

*** Settings ***
Library   pdf2text

*** Test Cases ***
pdfconvert
    ${pdftext}=    Convert Pdf To txt    <path_to_pdf>

&GT;

答案 1 :(得分:0)

通过将文件分成更小的块来解决问题。原因是Java实现对类文件的限制为64KB。所以在我的案例中,该课程的评估大小为446KB。