是否可以使用pdfquery的正则表达式?

时间:2015-10-13 19:57:33

标签: python regex pdfminer

我们可以使用正则表达式检测pdf中的文本(使用pdfquery或其他工具)吗?

我知道我们可以这样做:

pdf = pdfquery.PDFQuery("tests/samples/IRS_1040A.pdf")
pdf.load()
label = pdf.pq('LTTextLineHorizontal:contains("Cash")')
left_corner = float(label.attr('x0'))
bottom_corner = float(label.attr('y0'))
cash = pdf.pq('LTTextLineHorizontal:in_bbox("%s, %s, %s, %s")' % \
        (left_corner, bottom_corner-30, \
        left_corner+150, bottom_corner)).text()
print cash
'179,000.00'

但我们需要这样的事情:

pdf = pdfquery.PDFQuery("tests/samples/IRS_1040A.pdf")
pdf.load()
label = pdf.pq('LTTextLineHorizontal:regex("\d{1,3}(?:,\d{3})*(?:\.\d{2})?")')
cash = str(label.attr('x0'))
print cash
'179,000.00'

1 个答案:

答案 0 :(得分:2)

这不完全是对正则表达式的查找,但它可以格式化/过滤可能的提取:

SELECT acc.*, fin.* 
FROM consumers acc
LEFT JOIN finances fin ON fin.uid = acc.uid 
WHERE acc.id = '$userID';

我没有测试下一个,但也可能有效:

def regex_function(pattern, match):
    re_obj = re.search(pattern, match)
    if re_obj != None and len(re_obj.groups()) > 0:
        return re_obj.group(1)
    return None

pdf = pdfquery.PDFQuery("tests/samples/IRS_1040A.pdf")

pattern = ''
pdf.extract( [
('with_parent','LTPage[pageid=1]'),
('with_formatter', 'text'),
('year', 'LTTextLineHorizontal:contains("Form 1040A (")', 
        lambda match: regex_function(SOME_PATTERN_HERE, match)))
 ])