Я хотел сделать это (diff PDFs) недавно с этими требованиями:
- игнорировать пробелы, разрывы строк, разрывы страниц и т.д.
- легко видеть, когда изменилась только пара слов, а не только целые строки/пункты.
вывод цветового различия
я установил pdftotext, wdiff, и colordiff, доступные в различных пакетных менеджерах. (С макропортами: sudo port install poppler wdiff colordiff
)
Тогда:
wdiff <(pdftotext old.pdf -) <(pdftotext new.pdf -) | colordiff
Теперь я вижу, какие слова, красиво окрашенные, изменились.
Подробнее: http://philfreo.com/blog/how-to-view-a-color-diff-of-text-from-two-pdfs/
Вариант:
Использование dwdiff
может дать несколько лучшие результаты.
Я также хотел HTML вывод, так что этот крошечный скрипт делает базовую веб-страницу с небольшим количеством CSS.
bash pc-script.bash old.pdf new.pdf > q.htlm
Затем откройте q.html
своим веб-браузером.
pc-script.bash
файл:
#!/bin/bash
OLD="$1"
NEW="$2"
cat <<EOF
<html><head><meta charset="UTF-8"/><title>Changes from $OLD to $NEW</title></head><style>
.plus { color: green; background: #E7E7E7; }
.minus { color: red; background: #D7D7D7; text-decoration: line-through; }
</style><body><h1>Changes from [<span class="minus">$OLD</span>] to [<span class="plus">$NEW</span>]</h1><pre>
EOF
dwdiff -i -A best -P \
--start-delete='<span class="minus">' --stop-delete='</span>' \
--start-insert='<span class="plus" >' --stop-insert='</span>' \
<( pdftotext -enc UTF-8 -layout "$OLD" - ) \
<( pdftotext -enc UTF-8 -layout "$NEW" - ) \
cat <<EOF
</pre></body></html>
EOF
Пример вывода можно посмотреть здесь