一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python去除PDF水印的實現(xiàn)示例

Python去除PDF水印的實現(xiàn)示例

2022-02-22 12:49渡碼 Python

本文主要介紹了Python去除PDF水印的實現(xiàn)示例,思路很簡單,代碼也很簡潔。具有一定的參考價值,感興趣的可以了解一下

今天介紹下用 Python 去除 PDF (圖片)的水印。思路很簡單,代碼也很簡潔。

首先來考慮 Python 如何去除圖片的水印,然后再將思路復用到 PDF 上面。

Python去除PDF水印的實現(xiàn)示例

這張圖片是前幾天整理《數(shù)據(jù)結構和算法》PDF里的一個截圖,帶著公眾號的水印。

從上圖可以明顯看到,為了不影響閱讀正文,水印顏色一般比較淺。因此,我們可以利用顏色差這個特征來去掉水印。即:用 Python 讀取圖片的顏色,并將淺顏色部分變白。

Python 標準庫 PIL 可以獲取圖片的顏色,Python2 是系統(tǒng)自帶的,Python3 需要自己安裝,我用的 Python 3.8,需要執(zhí)行以下

命令安裝

?
1
pip install pillow

安裝完成,讀取圖片,并獲取圖片的尺寸(寬度和高度)

?
1
2
3
4
from PIL import Image
 
img = Image.open('watermark_pic.png')
width, height = img.size

進行下一步之前,先簡單介紹下計算機里關于顏色的知識。光學三原色是紅綠藍(RGB),也就是說它們是不可分解的三種基本顏色,其他顏色都可以通過這三種顏色混合而成,三種顏色等比例混合就是白色,沒有光就是黑色。

在計算機中,可以用三個字節(jié)表示 RGB 顏色,1個字節(jié)能表示的最大數(shù)值是 255, 所以,(255, 0, 0)代表紅色,(0, 255, 0)代表綠色,(0, 0, 255)代表藍色。相應地,(255, 255, 255)代表白色,(0, 0, 0)代表黑色。從(0, 0, 0) ~ (255, 255, 255) 之間的任意組合都可以代表一個不同的顏色。

接下來我們可以通過下面代碼讀取圖片的 RGB

?
1
2
3
4
for i in range(width):
    for j in range(height):
        pos = (i, j)
        print(img.getpixel(pos)[:3])

圖片每個位置顏色由四元組表示,前三位分別是 RGB,第四位是 Alpha 通道,我們不需要關心。

有了 RGB ,我們就可以對其修改。

Python去除PDF水印的實現(xiàn)示例

從圖中可以發(fā)現(xiàn),水印的 RGB 是 #d9d9d9,這里是用十六進制表示的,其實就是(217, 217, 217)。

這三個顏色值都越靠近 255,顏色就越淡,當它們都變成 255,也就成了白色。所以只要 RGB 都大于 217 的位置,我們都可以給它填成白色。即:RGB 三位數(shù)之和大于等于 651。

?
1
2
if sum(img.getpixel(pos)[:3]) >= 651:
    img.putpixel(pos, (255, 255, 255))

完整代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
from PIL import Image
 
img = Image.open('watermark_pic.png')
width, height = img.size
 
for i in range(width):
    for j in range(height):
        pos = (i, j)
        if sum(img.getpixel(pos)[:3]) >= 651:
            img.putpixel(pos, (255, 255, 255))
 
img.save('watermark_removed_pic.png')

有了上面的基礎,去除 PDF 的水印就簡單了,思路是將每頁 PDF 轉(zhuǎn)成圖片,然后修改水印的 RGB,最后輸出圖片即可。

安裝 pymupdf 庫,用來來操作 PDF

?
1
pip install pymupdf

讀取 PDF,并轉(zhuǎn)圖片

?
1
2
3
4
5
import fitz
 
doc = fitz.open("數(shù)據(jù)結構和算法手冊@公眾號渡碼.pdf")
for page in doc:
    pix = page.get_pixmap()

該 PDF 共 480 頁,所以需要遍歷每一頁,并獲取每一頁對應的圖片pix。pix對象類似于我們上面看到的img對象,可以讀取、修改它的 RGB。

page.get_pixmap() 這個操作是不可逆的,即能夠?qū)崿F(xiàn)從 PDF 到圖片的轉(zhuǎn)換,但修改圖片 RGB 后無法應用到 PDF 上,只能輸出為圖片。

修改水印 RGB 跟剛才一樣,區(qū)別是這里的 RGB 是一個三元組,沒有 Alpha 通道,代碼如下:

?
1
2
3
4
5
from itertools import product
 
for pos in product(range(pix.width), range(pix.height)):
    if sum(pix.pixel(pos[0], pos[1])) >= 651:
        pix.set_pixel(pos[0], pos[1], (255, 255, 255))

完整代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
from itertools import product
import fitz
 
 
doc = fitz.open("數(shù)據(jù)結構和算法手冊@公眾號渡碼.pdf")
 
page_no = 0
for page in doc:
    pix = page.get_pixmap()
 
    for pos in product(range(pix.width), range(pix.height)):
        if sum(pix.pixel(pos[0], pos[1])) >= 651:
            pix.set_pixel(pos[0], pos[1], (255, 255, 255))
 
    pix.pil_save(f"pdf_pics/page_{page_no}.png", dpi=(30000, 30000))
 
    print(f'第 {page_no} 頁去除完成')
    page_no += 1

這種方案是有缺點的,第一,輸出并非 PDF 格式;第二,輸出的圖片比較模糊,后續(xù)還有待優(yōu)化,最好是能直接修改 PDF。

到此這篇關于Python去除PDF水印的實現(xiàn)示例的文章就介紹到這了,更多相關Python去除PDF水印內(nèi)容請搜索服務器之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/duma/p/15491801.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 午夜理论片YY4399影院 | 欧美同志gaypronvideos | 关晓彤被草| 9久爱午夜视频 | 秋霞啪啪网 | 九九九国产在线 | 好爽好粗 | 亚洲va精品中文字幕 | 我的漂亮朋友在线观看全集免费 | 办公室大战秘书呻吟 | 欧美日韩在线一区二区三区 | 日本视频免费在线 | 日本69sex护士www | 欧美激情精品久久久久久不卡 | 亚洲成人福利 | 男人晚上适合偷偷看的污污 | 成人网久久 | 国产精品va在线观看手机版 | 国产成人刺激视频在线观看 | 国产精品高清一区二区三区不卡 | 免费看一级a一片毛片 | h视频免费高清在线观看 | 毛片群 | 欧美男人天堂 | 超碰成人在线播放 | 爱操综合网 | 国产亚洲精品网站 | 91这里只有精品 | haodiaose在线精品免费观看 | aaaaa特级毛片 | 久久青青草原精品国产软件 | 免费理伦片手机在线播放 | 欧美a级在线观看 | 亚洲精品免费在线观看 | porno美国xxxx| 火影小南被爆羞羞网站 | 9总探花新品牛仔背带裤 | 秋霞在线观看成人高清视频51 | 亚洲AV精品一区二区三区不卡 | 日韩欧美一卡二区 | 亚洲天堂男人网 |