microsoft-office – Excel文件越来越大(> 150 MB)

我公司的一些员工使用了一个特定的Excel文件.它在Excel 2003和2007中进行了编辑,启用了“共享”功能,允许一次编写多个编写器.

文件在几张纸上有大量数据,带有一些基本格式,过去约为6MB,这对其内容来说似乎是合理的.但经过几周的编辑后,文件增长到10,然后是20 MB,最终飙升至超过150 MB,尽管它仍然拥有与之前大致相同的数据量.它现在需要5-10分钟才能打开它,并且需要花费很多时间来保存它.

第一次发生这种情况时,我将每个工作表的内容复制到一个新的空白工作簿中,并保存了新工作簿;这使它恢复到大约6MB.现在,它再次爆炸了.

该工作簿使用“数据验证”功能将某些列中的值限制为几个命名范围的内容.将所有数据复制到新工作簿意味着重新设置所有数据验证,这是一个痛苦,而不是我们每个月都想做的事情.

作为故障排除步骤,我尝试以“XML Spreadsheet 2003”格式保存文件,希望能够深入了解存储的内容.果然,该文件几乎是一个演出,几乎所有1000万行看起来像这样:

<NamedCell ss:Name="Z_21D5114F_E50C_46AC_AA4F_C3FF540C717F_.wvu.FilterData"/>
<NamedCell ss:Name="Z_1EE2BA5E_3011_4F9A_8ACD_E58835250FC4_.wvu.FilterData"/>
<NamedCell ss:Name="Z_1E3BDCEA_6A72_4ECC_BF4F_7B03CC66181E_.wvu.FilterData"/>

我在网上看到了一些VBScripts来管理和枚举隐藏在Excel内置界面中的命名单元格,不过我想知道它们是如何处理我的1000万个命名单元格的.但是,我真正需要的是理解为什么会这种情况不断发生. excel中的哪些操作可能会导致这种情况?

更新:

这是我试过的一个实验,它提供了一些更详细的信息:

>我关掉了分享;文件仍然很大.
>我将文件保存为.xlsx文件,并缩小到5MB.
>然后我关闭了该文件,将其打开并将其保存为.xls文件,共享仍然关闭;它又变大了!
>当’03用户试图打开那个漂亮的,紧凑的.xlsx文件时,打开它需要几分钟,即使’07打开它也没关系.

因此,这似乎是一个’03特定问题,并以’03格式保存文件立即重新创建了一堆显然根本没有在’07文件中的垃圾.

跟我说吧:Excel不是数据库.

你遇到了软件的设计限制:它只有很多存储事务数据的能力,所以当多个人写信时,它必须存储一些信息来协调.你有太多的数据,交易副本是巨大的.

Microsoft(正确地)假定如果您拥有那么多数据,它将存储在数据库中,而您只是使用Excel作为前端.

如果你打算这样工作,你至少应该把一个小的Access数据库拼凑起来.它将为您节省一个令人头痛的世界,因为它意味着像那样工作而Excel就是这样.

@Josh:是的,它绝对是泄漏的.当您共享文档时,它必须跟踪每个用户所做的修改……我将其称为“事务性数据”,但您可以将其视为历史记录.由于从来没有“官方”版本,它会不断跟踪变化,文件比甜甜圈店里的Kirstie Alley更快.

这是设计的.作为excel guru的人可能能告诉你如何让它停止,但最好的解决方案就是不要将excel用于经常维护的数据.它并不是它的设计目标.

我很同情你的问题,但这是一个更好的解决方案,向上级解释问题并制定一个新的程序,而不是试图延长一个不幸的黑客.

@Josh:如果您只想暂时缩小一次,请复制所有数据,然后将其粘贴到新的电子表格中.这将杀死所有元数据,保证(确保你不选择整个工作表,但只选择包含数据的部分)但这是一个临时解决方案.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Windows注册表操作基础代码 Windows下对注册表进行操作使用的一段基础代码Reg.h:#pragmaonce#include&lt;assert.h&gt;#include&lt;windows.h&gt;classReg{HKEYhkey;public:voidopen(HKEYroot
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的内容,在Windows环境下的黑客必须熟练掌握底层API编程。为了使读者对黑客常用的Windows API有个更全面的了解以及方便日后使用API方法的查询,特将这些常用的API按照7大分类进行整理如下,希望对大家的学习有所帮助。一
一个简单的Windows Socket可复用框架说起网络编程,无非是建立连接,发送数据,接收数据,关闭连接。曾经学习网络编程的时候用Java写了一些小的聊天程序,Java对网络接口函数的封装还是很简单实用的,但是在Windows下网络编程使用的Socket就显得稍微有点繁琐。这里介绍一个自己封装的一
Windows文件操作基础代码 Windows下对文件进行操作使用的一段基础代码File.h,首先是File类定义:#pragmaonce#include&lt;Windows.h&gt;#include&lt;assert.h&gt;classFile{HANDLEhFile;//文件句柄publ
Winpcap基础代码 使用Winpcap进行网络数据的截获和发送都需要的一段代码:#include&lt;PCAP.H&gt;#pragmacomment(lib,&quot;wpcap.lib&quot;)//#pragmacomment(lib,&quot;ws2_32.lib&quot;)#
使用vbs脚本进行批量编码转换 最近需要使用SourceInsight查看分析在Linux系统下开发的项目代码,我们知道Linux系统中文本文件默认编码格式是UTF-8,而Windows中文系统中的默认编码格式是Gb2312。系统内的编码格式有所区别倒无伤大雅,关键的是SourceInsigh...
缓冲区溢出攻击缓冲区溢出(Buffer Overflow)是计算机安全领域内既经典而又古老的话题。随着计算机系统安全性的加强,传统的缓冲区溢出攻击方式可能变得不再奏效,相应的介绍缓冲区溢出原理的资料也变得“大众化”起来。其中看雪的《0day安全:软件漏洞分析技术》一书将缓冲区溢出攻击的原理阐述得简洁
Windows字符集的统一与转换一、字符集的历史渊源在Windows编程时经常会遇到编码转换的问题,一直以来让刚接触的人摸不着头脑。其实只要弄清Win32程序使用的字符编码方式就清楚了,图1展示了一个Win32控制台项目的属性中的字符集选项。这里有两个不同的字符集:一个是Unicode字符集,另一个
远程线程注入引出的问题一、远程线程注入基本原理远程线程注入——相信对Windows底层编程和系统安全熟悉的人并不陌生,其主要核心在于一个Windows API函数CreateRemoteThread,通过它可以在另外一个进程中注入一个线程并执行。在提供便利的同时,正是因为如此,使得系统内部出现了安全
windows系统启动项怎么打开
win10系统文件夹的只读属性去不掉怎么办
windows.old可以删掉吗?
windows的网络功能主要通过什么来实现?
win10系统以太网不见了怎么办
win10安装cad缺少net组件怎么办
win10系统鼠标移动方向相反怎么办
如何ping局域网内所有IP
windows10的系统保留分区有什么用
win10系统无法删除账户怎么办
win10系统音频服务未响应怎么办