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

做网站需要几步wordpress主题q9

做网站需要几步,wordpress主题q9,discuz网站标题,wordpress登录地址怎么修改需求#xff1a; 读出excel的图片内容#xff0c;这放在微软三件套是很容易的#xff0c;但是由于wps的固有格式#xff0c;会出现奇怪的问题#xff0c;只能读出#xff1a;类似于 DISPIMG(“ID_2B83F9717AE1XXXX920xxxx644C80DB1”,1) 【该DISPIMG函数只有wps才拥有】 …需求 读出excel的图片内容这放在微软三件套是很容易的但是由于wps的固有格式会出现奇怪的问题只能读出类似于 DISPIMG(“ID_2B83F9717AE1XXXX920xxxx644C80DB1”,1) 【该DISPIMG函数只有wps才拥有】 本文参考该多个作者的思路 https://blog.csdn.net/maudboy/article/details/133145278 java读取Excel,(支持WPS嵌入式图片) 以及该github issus: https://github.com/qax-os/excelize/issues/664 How to read pictures embedded in cells 当然该项目两个个月前用go 来读取wps中的图片格式https://github.com/qax-os/excelize excelize 希望大家多多关注 github前几名的excel读取,python在后几名【这让我挺吃惊的作为第一语言支持库这么多竟然没有对wps图片解析的python代码】第一是Go写的。 首先明确xlsx就是一个zip包否则里面的图片根本没法读取。 下面是该代码的思路 # xlsx本质就是zip,其解压文件夹为_rels xl docProps # 代码思路首先读取excel表并提取DISPIMG_id列保存在image_list中 # 根据xl/cellimages.xml 提取出rId与DISPIMG_id的关系组成一个map1,{DISPIMG_id:rId} # 再根据xl/_rels/cellimages.xml.rels根据rId 与 imgae_path的关系,组成一个map2 {rId:image_path} # 根据map1与map2对应的关系组成一个新map3 : {DISPIMG_id: image_path} 得出对应的关系 # 输出图片根据xl/{image_path} 输出图片并把图片重命名为DISPIMG_id.png代码思路该代码可以优化主要多次读取文件并且多次调用map了不过处理几百条数据还是绰绰有余的。 import zipfile import os import xml.etree.ElementTree as ET import openpyxlimage_list [] # 存放从excel读出的DISPIMG_iddef read_excel_data(filename_path):# 加载 Excel 文件workbook openpyxl.load_workbook(filename_path, data_onlyFalse)sheet workbook.active# 遍历数据和公式data [] # data就是文本信息for row in sheet.iter_rows(min_row1, values_onlyFalse):row_data []for cell in row:if cell.value and isinstance(cell.value, str) and _xlfn.DISPIMG( in cell.value:# 提取嵌入的图片 IDformula cell.valuestart formula.find() 1end formula.find(, start)image_id formula[start:end]row_data.append(f{image_id})image_list.append(image_id)# print(image_id)else:# 其他数据直接添加row_data.append(cell.value)data.append(row_data)return datadef get_xml_id_image_map(xlsx_file_path):# 打开 XLSX 文件with zipfile.ZipFile(xlsx_file_path, r) as zfile:# 直接读取 XML 文件内容with zfile.open(xl/cellimages.xml) as file:xml_content file.read()with zfile.open(xl/_rels/cellimages.xml.rels) as file:relxml_content file.read()# 将读取的内容转换为 XML 树root ET.fromstring(xml_content)# 初始化映射字典name_to_embed_map {}# 命名空间namespaces {xdr: http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing,a: http://schemas.openxmlformats.org/drawingml/2006/main}# 遍历所有 pic 元素for pic in root.findall(.//xdr:pic, namespacesnamespaces):name pic.find(.//xdr:cNvPr, namespacesnamespaces).attrib[name]embed pic.find(.//a:blip, namespacesnamespaces).attrib[{http://schemas.openxmlformats.org/officeDocument/2006/relationships}embed]name_to_embed_map[name] embed# 打印结果# print(name_to_embed_map)root1 ET.fromstring(relxml_content)# 命名空间字典根据 XML 中定义的命名空间进行设置namespaces {r: http://schemas.openxmlformats.org/package/2006/relationships}# 创建 ID 和 Target 的映射id_target_map {child.attrib[Id]: child.attrib.get(Target, No Target Found) for child inroot1.findall(.//r:Relationship, namespacesnamespaces)}# print(id_target_map)# 使用字典推导构建新的映射表name_to_target_map {name: id_target_map[embed] for name, embed in name_to_embed_map.items() ifembed in id_target_map}return name_to_target_mapdef output_id_image(xlsx_file_path):read_excel_data(xlsx_file_path)name_to_target_map get_xml_id_image_map(xlsx_file_path)# 构建id_image_对new_map {key: name_to_target_map.get(key) for key in image_list if key in name_to_target_map}print(new_map)output_directory ./images #保存的图片目录# 打开xlsx文件即Zip文件with zipfile.ZipFile(xlsx_file_path, r) as zfile:for key, image_path in new_map.items():# 构建实际的图片路径actual_image_path fxl/{image_path} # 假设图片在xl/media/目录下if actual_image_path in zfile.namelist():# 读取图片内容with zfile.open(actual_image_path) as image_file:image_content image_file.read()# 保存图片到新的文件使用key作为文件名new_file_path os.path.join(output_directory, f{key}.png)with open(new_file_path, wb) as new_file:new_file.write(image_content)else:print(fFile {actual_image_path} not found in the archive.)if __name__ __main__:output_id_image(/home/jacin/Downloads/英式货表.xlsx)# 输出的图片名字就是 xlsx表中的列的DISPIMG_id保存在images文件夹下# 并会在控制台输出一个字典key是DISPIMG_idvalue是图片的路径,例如{ID_BE7EFF591B6C4978XXXXXX5266: media/image118.png}
http://www.dnsts.com.cn/news/265743.html

相关文章:

  • 建站软件免费模板没有网站没有推广如何做外贸
  • 建设购物网站的方案东莞网站建设培训
  • 深圳宝安网站建设工wordpress如何修改密码
  • 一个网站的建设要经过哪几个阶段自力教育
  • 建设部资质网站查询自己做网站能关联支付宝吗
  • 赣州网站制作培训淘宝内部卷网站怎么做
  • 做淘客应该知道的网站拖拽式网站建设源码
  • 丰都县网站个人网站 icp 代理
  • 多种成都网站建设wordpress主题转html
  • 网站支付端口仪征做网站公司
  • 几种语言的网站如何做网站运营岗位介绍
  • 利用高权重网站做关键词天津中心网站建设
  • 网站体验方案网页界面设计与分析
  • 网站建设属于什么行业哪个公司建网站
  • 合肥瑶海区寒假兼职工网站建设抓取资源的网站怎么做
  • 备案网站查询网站背景图片素材
  • 揭阳自助建站网站建设php招聘
  • 手机端网站模板下载php一个空间放多个网站
  • 网站ip pv值专门做配电箱的网站
  • 传奇服务器如何做网站wordpress设置logo和公司名
  • 网站收录变少荆门做网站公众号的公司
  • 做网盘搜索网站crm排名
  • 建站行业有前途广州建设网站是什么
  • 国外优秀网站建设广州网站建设培训
  • 企业网站关键词排名网站后台标签切换
  • 天水模板型网站建设关键词seo是什么意思
  • 网站建设的行业动态网站建设分为多少模块
  • 网站结的建设ppt软件公司招聘信息
  • 在哪些网站做外贸好巩义便宜网站建设费用
  • 专做婚宴用酒是网站百度收录wordpress