当前位置:首页教育技巧word技巧word图表制作

word中统计图怎么去掉边框,Python去掉图片四周纯色边框

减小字体 增大字体 2025-01-26 12:03:34


去白边框.py,彩蛋在最后。

from skimage import io def corp_margin(img): img2=img.sum(axis=2) (row,col)=img2.shape row_top=0 raw_down=0 col_top=0 col_down=0 for r in range(0,row): if img2.sum(axis=1)[r]<1000*col:#>255去除黑边 row_top=r break for r in range(row-1,0,-1): if img2.sum(axis=1)[r]<1000*col:#>255去除黑边 raw_down=r break for c in range(0,col): if img2.sum(axis=0)[c]<1000*row:#>255去除黑边 col_top=c break for c in range(col-1,0,-1): if img2.sum(axis=0)[c]<1000*row:#>255去除黑边 col_down=c break new_img=img[row_top:raw_down+1,col_top:col_down+1,0:3] return new_img im = io.imread('白边框.png') img_re = corp_margin(im) io.imsave('白边框-bak.png',img_re)

去黑边框.py

from skimage import io def corp_margin(img): img2=img.sum(axis=2) (row,col)=img2.shape row_top=0 raw_down=0 col_top=0 col_down=0 for r in range(0,row): if img2.sum(axis=1)[r]>255*col:#<1000去除白边 row_top=r break for r in range(row-1,0,-1): if img2.sum(axis=1)[r]>255*col:#<1000去除白边 raw_down=r break for c in range(0,col): if img2.sum(axis=0)[c]>255*row:#<1000去除白边 col_top=c break for c in range(col-1,0,-1): if img2.sum(axis=0)[c]>255*row:#<1000去除白边 col_down=c break new_img=img[row_top:raw_down+1,col_top:col_down+1,0:3] return new_img im = io.imread('黑边框.png') img_re = corp_margin(im) io.imsave('黑边框-bak.png',img_re)

下面是解释说明:pip install scikit-image

我用的ide是Thonny一个简单易用的python 编译器。

如果你只是要用,可以不看下面的。下面的是原理讲解,彩蛋在最后。



在网上下载的图片往往存在外面为一圈黑色或者白色的边框。现在我们来学习采用python自动裁剪掉四周不需要的边框。

以下面这两张图为例子,一张有纯黑色边框,一张有纯白色边框。

白边框(蓝色为word边框,实际图片不存在)

黑边框


先来去掉黑色边框。我们知道黑色的RGB值是[0,0,0],但是在skimage中黑色为[0,0,0,255],白色为[255 255 255 255]。

因此大体思路就是先获取整张图片的像素,比如黑边框.png的信息可以用右键查看属性如下:


黑边框

白边框


也就是说这张图有298行+324列像素(白色边框为:281行+275列像素)。然后逐行和逐列去判断,所有像素点RGB值之和。

理论上只需要大于0+0+0+255就可以认为是内容部分了。但是这里为了防止有些比较接近于黑色的纯色边框,我们把阈值设为255或者255+50。这个值可以自己根据需要调节。

Rgb可以通过word里面的字体这个查看:

这个阈值可以通过以下代码来查看:

通过print来计算阈值:255*298(像素)=75990,所以阈值选择255。

说明:Print(img) [0 0 0 255];全白应该是[255 255 255 255];全黑应该是[0 0 0 255]

黑边框

去除黑边框后


那么相应的去除白色边框也很容易了,白色的RGB值是[255,255,255,

255],因此只需要像素点RGB之和小于255*4=1020,按照1000就可以了。


白边框

去除白边框

如果是其它颜色,那你查看下他的rgb,然后定个范围就可以了。

其他颜色的纯色边框,可以自己去尝试调节RGB的阈值来实现。

最后结论:

全白为[255,255,255,255],255+255+255+255=1020按照1020或者1000作为阈值。

全黑为[0,0,0,255],0+0+0+255=255按照255或者 50+255=305作为阈值。

彩蛋留给看到最后的你,批量修改,只需修改路径即可。

# encoding: utf-8 from skimage import io def corp_margin(img): img2=img.sum(axis=2) (row,col)=img2.shape row_top=0 raw_down=0 col_top=0 col_down=0 for r in range(0,row): if img2.sum(axis=1)[r]>255*col:#<1000去除白边 row_top=r break for r in range(row-1,0,-1): if img2.sum(axis=1)[r]>255*col:#<1000去除白边 raw_down=r break for c in range(0,col): if img2.sum(axis=0)[c]>255*row:#<1000去除白边 col_top=c break for c in range(col-1,0,-1): if img2.sum(axis=0)[c]>255*row:#<1000去除白边 col_down=c break new_img=img[row_top:raw_down+1,col_top:col_down+1,0:3] return new_img import os path = "C:\Users\Administrator\Desktop\办公常用py(1)\新建文件夹\" #可以改为你自己的路径,注意斜杠方向 # 批量添加图片,后面的参数设置图片尺寸,可以选填 files=os.listdir(path) 数量=len(files) print(files,数量) print(files[1]) for i in range(数量): im = io.imread(path +files[i]) img_re = corp_margin(im) io.imsave(path +"bak"+files[i],img_re)

评论评论内容只代表网友观点,与本站立场无关!

   评论摘要(共 0 条,得分 0 分,平均 0 分)

【免责声明】本站信息来自网友投稿及网络整理,内容仅供参考,如果有错误请反馈给我们及时更正,对文中内容的真实性和完整性本站不提供任何保证,不承但任何责任。
版权所有:学窍知识网 Copyright © 2011-2025 www.at317.com All Rights Reserved .