深入解析Excel文件格式:.xls与.xlsx的差异与应用指南

        在当今的数据处理和办公自动化领域Microsoft Excel 无疑是一款极为重要的工具。

        它不仅广泛应用于日常的数据录入、计算和图表制作,而且也是数据分析、财务建模等专业

领域不可或缺的软件。Excel 的文件格式经历了多个版本的迭代,其中  .xls  和  .xlsx  是最常见的

两种格式。

        本文将深入探讨这两种格式之间的区别,并探讨它们在实际应用中的影响。

文件格式剖析

        .xls 格式:最初随 Excel 97 引入,并在后续的 Excel 2000、2002、2003 版本中得到支

持。.xls 是一种基于二进制的文件格式,它的结构较为复杂,不易被其他应用程序解析。由于其封

闭性,对文件进行直接编辑和修改存在一定难度。

        .xlsx 格式:自 Excel 2007 起成为默认的文件格式,基于 Office Open XML 标准。.xlsx 是一

种压缩的 XML 文件格式,这使得它的结构更加清晰,易于被其他应用程序读取和写入。XML 的开

放性也促进了数据交换和集成。

兼容性与功能差异

        兼容性:.xls 格式由于年代久远,不支持 Excel 2007 后引入的诸多高级功能。例如,.xls 文

件的工作表大小受限,列数最多只能达到 256 列,而行数最多为 65,536 行。而 .xlsx 格式则支持

多达 1,048,576 行和 16,384 列,极大地扩展了数据处理能力。

        功能支持:.xlsx 格式支持更多高级功能,如条件格式的高级应用、数据透视表的增强、复杂

公式的运用等。此外,.xlsx 文件还支持高级数据验证,这对于确保数据输入的准确性和一致性至

关重要。

大小、性能与安全性

        文件大小与性能:由于采用了压缩技术,.xlsx 文件通常比 .xls 文件体积更小,这在数据传输

和存储方面具有明显优势。同时,.xlsx 文件的打开和保存速度更快,这在处理大型数据集时尤为

显著。

        安全性:在安全性方面,.xlsx 格式提供了更高级别的支持。用户可以为 .xlsx 文件设置加密

和数字签名,确保数据的安全性。这对于涉及敏感信息的文件尤为重要。

在 Pandas 中的读取与应用

        在 Python 的数据处理库 Pandas 中,读取 Excel 文件是一项基本操作。下面是针对不同格

式文件的读取方法

import pandas as pd# 读取 .xls 文件df_xls = pd.read_excel('file.xls', engine='xlrd')# 读取 .xlsx 文件df_xlsx = pd.read_excel('file.xlsx', engine='openpyxl')

        随着 Pandas 和相关依赖库的更新,对文件格式的支持也在不断变化。例如, xlrd  库在

2.0.0 版本之后不再支持读取 .xlsx 文件,因此在使用 Pandas 读取 .xls 文件时,可能需要安装特

定版本的  xlrd  库。

结论

        总而言之,.xlsx 格式由于其开放性、兼容性和先进的功能,已经成为 Excel 文件处理的主流

格式。

        然而,由于历史原因和特定需求,.xls 格式仍然在一定范围内被使用。

        我在初次使用的时候遇到了这个问题

        ImportError: Missing optional dependency 'xlrd'. Install xlrd >= 2.0.1 for xls Excel

support Use pip or conda to install xlrd.

        这个错误信息表明,Pandas 在尝试读取 .xls 格式的 Excel 文件时,缺少了 xlrd 这个可选依赖

库,或者安装的 xlrd 版本不满足要求(低于 2.0.1 版本)。下面是解决这个问题的步骤

1. 安装 xlrd 库

        如果你还没有安装 xlrd,可以使用以下命令来安装(命令行 cmd ):

pip install xlrd

        如果你使用的是 Anaconda 环境,可以使用如下命令:1

conda install xlrd

2. 确保安装的是正确版本的 xlrd

        从 xlrd 2.0.0 版本开始,它不再支持读取 .xlsx 文件,但仍然支持 .xls 文件

确保安装的 xlrd 版本至少是 2.0.1,可以使用下面命令来升级到最新版本: 

pip install --upgrade xlrd

        或者对于 Anaconda 环境使用如下命令:

conda update xlrd

3. 确认 xlrd 已正确安装

        安装完成后,你可以通过以下 Python 代码来检查 xlrd 是否已经正确安装并且版本满足要求:

import xlrdprint(xlrd.__VERSION__)

        这会打印出 xlrd 的版本号,确保它至少是 2.0.1。

输出结果

94fd30847ec64ffc914b748d0770b2d8.png

4. 使用正确的引擎读取 Excel 文件

        使用 Pandasread_excel 函数时,确保我们指定了正确的引擎来读取 .xls 文件:

import pandas as pddf = pd.read_excel('file.xls', engine='xlrd')

        另外,如果我们的目的是读取 .xlsx 文件,那么我们应该使用 openpyxl 而不是 xlrd,因为

openpyxl 是用于读取和写入 .xlsx 文件的库。

        安装 openpyxl 的代码如下

pip install openpyxl

        然后在读取 .xlsx 文件指定 openpyxl 作为引擎:

df = pd.read_excel('file.xlsx', engine='openpyxl')

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/55164.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

二叉树进阶oj题【二叉树相关10道oj题的解析和c++代码实现】

目录 二叉树进阶oj题1.根据二叉树创建字符串2.二叉树的层序遍历3.二叉树的层序遍历 II4.二叉树的最近公共祖先5.二叉搜索树和双向链表6.从前序与中序遍历序列构造二叉树7.从中序和后序遍历序列来构造二叉树8.二叉树的前序遍历,非递归迭代实现9.二叉树中序遍历 &…

部标主动安全(ADAS+DMS)对接说明

1.前言 上一篇介绍了部标(JT/T1078)流媒体对接说明,这里说一下如何对接主动安全附件服务器。 流媒体的对接主要牵扯到4个方面: (1)平台端:业务端系统,包含前端呈现界面。 &#x…

博弈论(学习笔记)

定义何为最优! 最优解是均衡!() 一次博弈 --- 一面之缘 复杂动态博弈; 路怒症----陌生人,一次性博弈。 一次性博弈最能暴露人性。 重复博弈太压抑了。 沙普利求解合作博弈的著名理论---如何为参与者制定利益…

GDAL Unable to open EPSG support file gcs.csv

python环境从3.6升级到3.7,gdal版本从2.2.4升级到3.4.1之后,执行原来的gdal脚本,结果报出如下错误 ”ERROR 4: Unable to open EPSG support file gcs.csv. Try setting the GDAL_DATA environment variable to point to the directory conta…

python画图|自制渐变柱状图

在前述学习过程中,我们已经通过官网学习了如何绘制渐变的柱状图及其背景。 掌握一门技能的最佳检验方式就是通过实战,因此,本文尝试做一些渐变设计。 前述学习记录可查看链接: Python画图|渐变背景-CSDN博客 【1】柱状图渐变 …

AI产品经理PRD文档与传统产品经理PRD有什么不同呢?

目录 模型输出:说白了,就是你的AI要干啥数据接入:你的AI要吃啥“粮食”验收标准:怎么判断你的AI干得好不好经验总结 你好,我是三桥君 在工作中,当我作为传统产品经理时,通常只需提供产品需求文…

【内网渗透】最保姆级的春秋云镜Flarum打靶笔记

目录 flag1 flag3 flag4​ flag2 flag1 扫外网 打的是flarum论坛,p牛之前有写过phar反序列化的利用: 从偶遇Flarum开始的RCE之旅 rockyou.txt爆出administrator/1chris,登录 用这个工具生成phar包 https://github.com/ambionics/p…

详解mysql和消息队列数据一致性问题

目录 前言 保持系统数据同步(双写问题) 消息队列消息丢失的问题 总结 前言 在当今互联网飞速发展的时代,随着业务复杂性的不断增加,消息队列作为一种重要的技术手段,越来越多地被应用于各种场景。它们不仅能有效解…

项目:微服务即时通讯系统客户端(基于C++QT)]四,中间界面搭建和逻辑准备

四,中间界面搭建 前言:当项目越来越复杂的时候,或许画草图是非常好的选择 一,初始化中间窗口initMidWindow void mainWidget::initMidWindow() {//使用网格布局进行管理QGridLayout* layout new QGridLayout();//距离上方 20px 的距离&…

Arthas redefine(加载外部的.class文件,redefine到JVM里 )

文章目录 二、命令列表2.2 class/classloader相关命令2.2.3 redefine(加载外部的.class文件,redefine到JVM里 )举例1:加载新的代码,jad/mc 命令使用举例2:上传 .class 文件到服务器的技巧 本人其他相关文章…

值传递和引用传递

值传递和引用传递是函数参数传递的两种类型,一般而言,基本数据类型都是值传递,数组和对象采用引用传递减少对象复制开销,但也有特例。 值和引用传递本质一样 值传递是拷贝值到函数参数,引用传递是拷贝引用(或者对象的指…

矿石运输船数据集、散货船数据集、普通货船数据集、集装箱船数据集、渔船数据集以及客船数据集

海船:用于船只检测的大规模精准标注数据集 我们很高兴地介绍一个新的大规模数据集——海船,该数据集专为训练和评估船只目标检测算法而设计。目前,这个数据集包含31,455张图像,并涵盖了六种常见的船只类型,包括矿石运…

Python基础语句教学

Python是一种高级的编程语言,由Guido van Rossum于1991年创建。它以简单易读的语法和强大的功能而闻名,被广泛用于科学计算、Web开发、数据分析等领域。 Python的应用领域广泛,可以用于开发桌面应用程序、Web应用、游戏、数据分析、人工智能等…

计算机视觉实战项目4(图像分类+目标检测+目标跟踪+姿态识别+车道线识别+车牌识别+无人机检测+A*路径规划+单目测距与测速+行人车辆计数等)

往期热门项目回顾: 计算机视觉项目大集合 改进的yolo目标检测-测距测速 路径规划算法 图像去雨去雾目标检测测距项目 交通标志识别项目 yolo系列-重磅yolov9界面-最新的yolo 姿态识别-3d姿态识别 深度学习小白学习路线 AI健身教练-引体向上-俯卧撑计数…

Python的异步编程

什么是协程? 协程不是计算机系统提供,程序员人为创造。 协程也可以被称为微线程,是一种用户态内的上下文切换技术。简而言之,其实就是通过一个线程实现代码块相互切换执行。 实现协程有那么几种方法: greenlet&…

Centos怎么执行脚本

方法一:切换到shell脚本所在的目录(此时,称为工作目录)执行shell脚本 cd /data/shell ./hello.sh 方法二:以绝对路径的方式去执行bash shell脚本 /data/shell/hello.sh 方法三:直接使用bash 或sh 来执行…

CSS外边距

元素的外边距(margin)是围绕在元素边框以外(不包括边框)的空白区域,这片区域不受 background 属性的影响,始终是透明的。 为元素设置外边距 默认情况下如果不设置外边距属性,HTML 元素就是不会…

Linux shell编程学习笔记84:tee命令——显示保存两不误

0 引言 在前面的学习笔记中,我们经常使用echo命令和输出重定向来生成脚本文件或演示文件,其实Linux提供了一个可以从标准输入读取数据,并输出成文件的命令——tee。 1 tee命令 的帮助信息、功能、命令格式、选项和参数说明 1.1 tee命令 的…

软件测试学习笔记丨Pytest 学习指南

本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/32336 基本介绍 pytest框架是一个成熟,全面的测试框架,具有非常丰富的第三方插件,并且可以自定义扩展 比如:pytest-selenium , pytest-html ,…

MySQL高阶2004-职员招聘人数

目录 题目 准备数据 分析数据 实现 题目 一家公司想雇佣新员工。公司的工资预算是 70000 美元。公司的招聘标准是: 雇佣最多的高级员工。在雇佣最多的高级员工后,使用剩余预算雇佣最多的初级员工。 编写一个SQL查询,查找根据上述标准雇…