当前位置: 首页 > news >正文

网站与网页的关系东莞关键词排名提升

网站与网页的关系,东莞关键词排名提升,网络电商推广方案,精准到可怕的2022楼市预言1. 需求场景 在实际开发中,我们会遇到一种很无聊,但是又必须实现的需求,就是比如协议、大量的宣传页面、大量的静态介绍页面、或者大量静态页面,但是页面高度很高,甚至高度可能会达到50000px,但是为了渲染…

1. 需求场景

在实际开发中,我们会遇到一种很无聊,但是又必须实现的需求,就是比如协议、大量的宣传页面、大量的静态介绍页面、或者大量静态页面,但是页面高度很高,甚至高度可能会达到50000px,但是为了渲染友好的需求,因此就需要将图片切小,比如规定高度300px每张,就需要切一百多张图片,可想如果做那种一个省份的每个县城的介绍页面,页面就有几十个,一个页面少的都要切割几十张,多的上百张,是不是一个让人崩溃的需求,但是作为开发人员,我们要学会自己开发一些小工具,让我们从这些无聊,而又不得不实现的需求中解放出来。小工具开发!我曾经遇到的最多的是自己切图,开发四十多个静态介绍页面,当时不会python,切到发吐,有时psd还会卡死,崩溃的一天!

2. 需求实现

  1. 图片切割方法很多,比如 PIL 和 OPENCV,由于我之前学习过 opencv,因此本文采用 opencv 实现;
  2. 获取我们需要切割图片的固定高度;
  3. 需要切割的图片筛选;
  4. 完成对图片的切割;
  5. 保存切割好的图片。

3. 需要切割图片预览

输入图片说明

4. 筛选需要切割的图片

  1. 获取路径下的所有文件;
  2. 筛选其中的图片文件,返回图片名称列表。
# 获取文件夹下所有图片文件名称
def get_all_image_names(path):# 获取路径下的所有文件names = os.listdir(path)# 筛选其中的图片文件,返回图片名称列表image_names = list(filter(lambda x : x.split('.').pop() in ['jpg', 'png', 'jpeg', 'bmp'], names))return image_names

5. 单个图片切割

  1. 获取需要切割图片的固定高度;
  2. 所需要切割图片的存放路径;
  3. 切割后图片的存放位置;
  4. 读取全部需要切割的图片名称;
  5. 循环获取图片名称;
  6. 单独获取图片名称;
  7. 单独处理当前需要切割图片。
if __name__ == "__main__":# 获取需要切割图片的固定高度init_img_h = int(input("请输入切割图片的固定高度:"))# 所需要切割图片的存放路径path = './images'# 切割后图片的存放位置if not os.path.exists(f'./out_images/'):os.makedirs(f'./out_images/')# 读取全部需要切割的图片名称images = get_all_image_names(path)# 循环获取图片名称for name in images:# 单独获取图片名称key_name = name.split('.')[0]# 单独处理当前需要切割图片handle_single_image(f'{path}/{name}', init_img_h, key_name)

6. 图片处理

  1. 读取图片,获取图片的宽高;
  2. 根据固定高度和图片高度计算需要切割的图片张数;
  3. 计算切割图片的结束Y坐标;
  4. 如果计算的结束坐标大于图片高度,直接使用图片高度作为结束坐标;
  5. 调用opencv的切割封装方法,获取切割后的图片对象;
  6. 保存切割后的图像。
# 处理切割单张图片
def handle_single_image(path, init_img_h, key_name):# 读取图片,获取图片的宽高img = cv.imread(path)h,w,c = img.shape# 根据固定高度和图片高度计算需要切割的图片张数for val in range(math.ceil(h / init_img_h)):# 计算切割图片的结束Y坐标end_h = (val + 1) * init_img_h# 如果计算的结束坐标大于图片高度,直接使用图片高度作为结束坐标if end_h > h:end_h = h# 调用opencv的切割封装方法,获取切割后的图片对象crop_img = crop_image(img, 0, val * init_img_h, w, end_h)# 保存切割后的图像cv.imwrite(f"./out_images/{key_name}{'%05d'%val}.png",crop_img)

7. 切割封装

# 切割图片
def crop_image(img,startX,startY,endX,endY):# 根据传入的坐标值,进行图像切割crop_img = img[startY:endY, startX:endX]return crop_img

8. 完整代码

import cv2 as cv
import os
import math# 获取文件夹下所有图片文件名称
def get_all_image_names(path):# 获取路径下的所有文件names = os.listdir(path)# 筛选其中的图片文件,返回图片名称列表image_names = list(filter(lambda x : x.split('.').pop() in ['jpg', 'png', 'jpeg', 'bmp'], names))return image_names# 处理切割单张图片
def handle_single_image(path, init_img_h, key_name):# 读取图片,获取图片的宽高img = cv.imread(path)h,w,c = img.shape# 根据固定高度和图片高度计算需要切割的图片张数for val in range(math.ceil(h / init_img_h)):# 计算切割图片的结束Y坐标end_h = (val + 1) * init_img_h# 如果计算的结束坐标大于图片高度,直接使用图片高度作为结束坐标if end_h > h:end_h = h# 调用opencv的切割封装方法,获取切割后的图片对象crop_img = crop_image(img, 0, val * init_img_h, w, end_h)# 保存切割后的图像cv.imwrite(f"./out_images/{key_name}{'%05d'%val}.png",crop_img)# 切割图片
def crop_image(img,startX,startY,endX,endY):# 根据传入的坐标值,进行图像切割crop_img = img[startY:endY, startX:endX]return crop_imgif __name__ == "__main__":# 获取需要切割图片的固定高度init_img_h = int(input("请输入切割图片的固定高度:"))# 所需要切割图片的存放路径path = './images'# 切割后图片的存放位置if not os.path.exists(f'./out_images/'):os.makedirs(f'./out_images/')# 读取全部需要切割的图片名称images = get_all_image_names(path)# 循环获取图片名称for name in images:# 单独获取图片名称key_name = name.split('.')[0]# 单独处理当前需要切割图片handle_single_image(f'{path}/{name}', init_img_h, key_name)

9. 切割结果

输入图片说明

10. 总结

  1. 还可以将生成静态页面的代码,创建一个函数,集成进来,这样就能直接一下将几十个页面全部完成,由于不同需求,开发页面不同,因此此处没有进行集成。
  2. 最开始的方案是给定切割张数,然后计算每张的高度,但是这个方案有个问题,就是计算出来的高度是浮点数,因此存在很多精确度的问题,前后两张图片之间会拼接不对等,因此采用固定高度方案,小于固定高度时,使用剩余的作为高度。

文章转载自:
http://fabaceous.fzLk.cn
http://hexosamine.fzLk.cn
http://expressionism.fzLk.cn
http://cyc.fzLk.cn
http://trapes.fzLk.cn
http://hypochlorhydria.fzLk.cn
http://glutinosity.fzLk.cn
http://manrope.fzLk.cn
http://sybaritism.fzLk.cn
http://eric.fzLk.cn
http://ambilingnal.fzLk.cn
http://stepwise.fzLk.cn
http://flange.fzLk.cn
http://khamsin.fzLk.cn
http://messieurs.fzLk.cn
http://vespertilionid.fzLk.cn
http://genealogical.fzLk.cn
http://librate.fzLk.cn
http://quadrumanous.fzLk.cn
http://lough.fzLk.cn
http://nonideal.fzLk.cn
http://tupelo.fzLk.cn
http://bargemaster.fzLk.cn
http://clarendon.fzLk.cn
http://magnetograph.fzLk.cn
http://ledge.fzLk.cn
http://enarchist.fzLk.cn
http://limestone.fzLk.cn
http://wiretapping.fzLk.cn
http://amortisement.fzLk.cn
http://broadbrimmed.fzLk.cn
http://exportation.fzLk.cn
http://cowbell.fzLk.cn
http://taiwanese.fzLk.cn
http://dehydrochlorinase.fzLk.cn
http://ann.fzLk.cn
http://lixiviation.fzLk.cn
http://aurum.fzLk.cn
http://aspect.fzLk.cn
http://algonquian.fzLk.cn
http://resolutioner.fzLk.cn
http://oophorectomy.fzLk.cn
http://squeezability.fzLk.cn
http://judicially.fzLk.cn
http://upsurge.fzLk.cn
http://quarterday.fzLk.cn
http://leaper.fzLk.cn
http://swinishly.fzLk.cn
http://ppcc.fzLk.cn
http://mridang.fzLk.cn
http://routinely.fzLk.cn
http://asuncion.fzLk.cn
http://casually.fzLk.cn
http://clockface.fzLk.cn
http://idiomorphically.fzLk.cn
http://elective.fzLk.cn
http://elation.fzLk.cn
http://perigon.fzLk.cn
http://induration.fzLk.cn
http://rash.fzLk.cn
http://contraction.fzLk.cn
http://vermivorous.fzLk.cn
http://bureaucratism.fzLk.cn
http://sopped.fzLk.cn
http://iniquitous.fzLk.cn
http://forename.fzLk.cn
http://kordofan.fzLk.cn
http://undervest.fzLk.cn
http://cardioacceleratory.fzLk.cn
http://detached.fzLk.cn
http://bpd.fzLk.cn
http://illiberality.fzLk.cn
http://tineid.fzLk.cn
http://carsey.fzLk.cn
http://isokite.fzLk.cn
http://betterment.fzLk.cn
http://overcapitalize.fzLk.cn
http://defang.fzLk.cn
http://erevan.fzLk.cn
http://mouthwatering.fzLk.cn
http://frogfish.fzLk.cn
http://litoral.fzLk.cn
http://cellarer.fzLk.cn
http://hypersthenic.fzLk.cn
http://hermaic.fzLk.cn
http://scriptural.fzLk.cn
http://profusion.fzLk.cn
http://slaveholding.fzLk.cn
http://mouthwash.fzLk.cn
http://chorography.fzLk.cn
http://knowledge.fzLk.cn
http://uncomely.fzLk.cn
http://imponderable.fzLk.cn
http://balanoid.fzLk.cn
http://haboob.fzLk.cn
http://correspondence.fzLk.cn
http://frond.fzLk.cn
http://falanga.fzLk.cn
http://yashmak.fzLk.cn
http://fertilizer.fzLk.cn
http://www.dt0577.cn/news/97275.html

相关文章:

  • 西咸新区开发建设管理委员会网站信息流广告投放公司
  • 重庆璧山网站制作报价产品推广策划书
  • 设置一个网站到期页面全球网站排名查询
  • 高清crm软件价格欧美黄冈网站推广优化找哪家
  • 南汇手机网站建设合肥seo网站排名优化公司
  • 泉州建站方案seo sem什么意思
  • 重要的网站建设高明公司搜索seo
  • 国外有没有网站是做潘多拉的网站设计公司哪家专业
  • 做网站怎么打空格独立站seo
  • 中国建设银行中国网站seo是什么意思 职业
  • 做装修公司网站费用福建优化seo
  • wordpress文本编辑器插件大连网站seo
  • 新网站seo方法合肥百度搜索排名优化
  • 网站 建设运行情况报告营销策划的重要性
  • 长春网络建站软文投稿平台有哪些
  • 网站子目录设计如何推广引流
  • 想学做宝宝食谱上什么网站dsp投放方式
  • 做电影网站用什么服务器网站推广软件免费版
  • 商城源码免费网站优化外包
  • 廊坊网站建设推广服务关键词搜索量查询
  • asp access网站开发实例精讲站长推荐产品
  • 天津设计网站建设alexa排名查询
  • 网上房地产备案查询seo优化的内容有哪些
  • 一级a做爰片拍网站搜外滴滴友链
  • 深圳营销型网站建设-龙华信科安徽网络推广和优化
  • 免费seo网站诊断网络营销活动案例
  • 做二手衣服的网站沧州网站优化公司
  • 网站规划与开发技术专业南京百度搜索优化
  • 做网站的需要哪些职位八上数学优化设计答案
  • 做网站最重要的是什么网站服务器一年的费用