- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
原始的 Office 文件运行没有问题(我尝试了 Word 和 Excel),但是当我将文件以二进制形式上传到数据库,然后将其下载到我的电脑并打开下载的文件时,我收到警告消息“excel 发现内容无法读取”等,并且该文件与原始文件相比变得更加简单。
确切的错误消息是:“Excel 在 filename.xls 中发现无法读取的内容。是否要恢复此工作簿的内容?如果您信任此工作簿的来源,请单击"is"。”
如何上传文件:
'UPLOAD FILE
Dim fi As New FileInfo(FilePath)
Dim s As Stream = fi.OpenRead()
Dim buffer(fi.Length) As Byte 'I put the buffer in database in varbinary(max) format
s.Read(buffer, 0, fi.Length)
s.Close()
如何下载并打开文件:
'DOWNLOAD FILE
Dim fi As New FileInfo(FilePath)
Dim s As Stream = fi.OpenWrite()
Dim buffer As Byte() = reader("Binary")
s.Write(buffer, 0, buffer.Length)
s.Close()
'OPEN FILE
Dim p As New Process
p.StartInfo = New ProcessStartInfo(FilePath)
p.Start()
更新:
按照建议,我尝试简单地复制文件,将 SQL 完全排除在外。这是我尝试过的代码,但也失败了:
Private Sub CopyFile(ByVal filePath As String)
Dim fi As New FileInfo(filePath)
Dim s As Stream = fi.OpenRead()
Dim buffer(CType(fi.Length, Integer) - 1) As Byte
s.Read(buffer, 0, CType(fi.Length, Integer))
s.Close()
Dim fi2 As New FileInfo(filePath & " Copy")
Dim s2 As Stream = fi2.OpenWrite()
s2.Write(buffer, 0, buffer.Length)
s2.Close()
End Sub
最佳答案
如this MSDN article所述VB.NET 数组的声明方式与其他语言(例如 C#)中的声明方式不同。在其他语言中,当声明固定长度数组时,给定的大小用作数组的总长度。例如,在 C# 中,语句 fixed byte buffer[3];
将声明一个包含 3 个元素(索引为 0 到 2)的字节数组。然而,在VB中,声明固定数组时给出的大小用作数组的上限,而不是大小。因此,在 VB 中,语句 Dim buffer(3) As Byte
声明一个包含 4 个元素(索引为 0 到 3)的字节数组。
考虑到这一点,如果仔细查看代码,您实际上是在声明一个字节数组,该数组比文件大小大一个元素(索引从 0 到 fi.Length)。然后,您将整个文件读入字节数组,从索引 0 开始。因此,数组中的最后一个字节保留为值 0(空字符)。然后,将字节数组的全部内容写入新文件,包括最后一个空字节。因此,您的代码正确地复制了文件中的所有字节,但在文件末尾添加了一个额外的空字节,这使 Excel 不满意。如果您查看原始文件大小和新创建文件的文件大小,您会发现新文件比原始文件大 1 个字节。
要解决此问题,您只需在声明数组时调整数组的大小,使其与文件的长度完全相同:
Dim buffer(fi.Length - 1) As Byte
但是,当我这样做时,我觉得有必要指出您发布的代码中的一些其他改进领域。首先,当使用实现IDisposable
接口(interface)的对象(例如Stream
)时,最好尽可能使用Using
语句。这样做可以确保对象始终被正确关闭/处置,即使遇到异常也是如此。例如,如果您这样做会更好:
Dim fi As New FileInfo(FilePath)
Using s As Stream = fi.OpenRead()
Dim buffer(fi.Length - 1) As Byte
s.Read(buffer, 0, fi.Length)
End Using
此外,很明显您没有使用 Option Strict
,因为如果使用的话,您将不被允许使用 fi.Length(a Long
)作为参数用于数组大小或缓冲区长度。如果您打开Option Strict
,您将被迫明确声明您要将Long
值转换为Integer
。例如:
Dim fi As New FileInfo(FilePath)
Using s As Stream = fi.OpenRead()
Dim buffer(CInt(fi.Length) - 1) As Byte
s.Read(buffer, 0, CInt(fi.Length))
End Using
在大多数情况下,打开Option Strict
是一个非常好的主意。它迫使您了解变量类型以及数据何时可能丢失。例如,在本例中,通过打开 Option Strict
,您会意识到文件大小 (Long.MaxValue
) 可能大于最大长度数组 (Integer.MaxValue
),因此,如果要处理非常大的文件,则需要编写一个循环来分块读取和写入文件。即使您不想处理大文件,最好先检查大小,以便可以优雅地处理错误,而不是允许抛出溢出异常:
If fi.Length >= Integer.Max Then
'Display or log error that the file is too large, and skip loading the file
Else
'Load file
End If
最后,如果您不关心处理大文件,有一种更简单的方法来读取和写入文件中的所有字节:
'UPLOAD FILE
Dim buffer() As Byte = File.ReadAllBytes(filePath)
'DOWNLOAD FILE
Dim buffer As Byte() = reader("Binary")
File.WriteAllBytes(filePath, buffer)
关于sql-server - 打开从 sql server 下载的 Office 文件时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12692392/
SQL、PL-SQL 和 T-SQL 之间有什么区别? 谁能解释一下这三者之间的区别,并提供每一个的相关使用场景? 最佳答案 SQL 是一种对集合进行操作的查询语言。 它或多或少是标准化的,几乎所有关
这个问题已经有答案了: What is the difference between SQL, PL-SQL and T-SQL? (6 个回答) 已关闭 9 年前。 我对 SQL 的了解足以完成我的
我在数据库中有一个 USER 表。该表有一个 RegistrationDate 列,该列有一个默认约束为 GETDATE()。 使用 LINQ 时,我没有为 RegistrationDate 列提供任
我有一个可能属于以下类型的字符串 string expected result 15-th-rp 15 15/12-rp 12 15-12-th
很难说出这里问的是什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或言辞激烈,无法以目前的形式合理回答。如需帮助澄清此问题以便可以重新打开,visit the help center . 9年前关闭
我有一个存储过程(称为 sprocGetArticles),它从文章表中返回文章列表。这个存储过程没有任何参数。 用户可以对每篇文章发表评论,我将这些评论存储在由文章 ID 链接的评论表中。 有什么方
我目前正在做一个 *cough*Oracle*cough* 数据库主题。讲师介绍embedded SQL作为让其他语言(例如 C、C++)与(Oracle)数据库交互的方式。 我自己做了一些数据库工作
SQL Server 中 SQL 语句的最大长度是多少?这个长度是否取决于 SQL Server 的版本? 例如,在 DECLARE @SQLStatement NVARCHAR(MAX) = N'S
这个问题已经有答案了: Simple way to transpose columns and rows in SQL? (9 个回答) 已关闭 8 年前。 CallType
预先感谢您对此提供的任何帮助。 假设我有一个查询,可以比较跨年的数据,从某个任意年份开始,永无止境(进入 future ),每年同一时期直到最后一个完整的月份(其特点是一月数据永远不会显示至 2 月
我在数据库中有一个 USER 表。该表有一个 RegistrationDate 列,该列的默认约束为 GETDATE()。 使用 LINQ 时,我没有为 RegistrationDate 列提供任何数
下面是我试图用来检查存储过程是否不存在然后创建过程的 sql。它会抛出一个错误:Incorrect syntax near the keyword 'PROCEDURE' IF NOT EXISTS
我有一个同事声称动态 SQL 在许多情况下比静态 SQL 执行得更快,所以我经常看到 DSQL 到处都是。除了明显的缺点,比如在运行之前无法检测到错误并且更难阅读,这是否准确?当我问他为什么一直使用
来自 lobodava 的动态 SQL 查询是: declare @sql nvarchar(4000) = N';with cteColumnts (ORDINAL_POSITION, CO
使用 SQL Server 中的存储过程执行动态 SQL 命令的现实优点和缺点是什么 EXEC (@SQL) 对比 EXEC SP_EXECUTESQL @SQL ? 最佳答案 sp_executes
我有这个有效的 SQL 查询: select sum(dbos.Points) as Points, dboseasons.Year from dbo.StatLines dbos i
我正在调试一些构建成功运行的 SQL 命令的代码。 然而,在查询结束时,查询结果似乎被写入了一个文本文件。 完整的查询如下 echo SELECT DATE,DATETABLE,DATE,APPDAT
我有一些创建表的 .sql 文件(MS SQL 数据库): 表_1.sql: IF OBJECT_ID (N'my_schema.table1', N'U') IS NOT NULL DROP TAB
我写了下面的 SQL 存储过程,它一直给我错误@pid = SELECT MAX(... 整个过程是: Alter PROCEDURE insert_partyco @pname varchar(20
我在 SQL Server 2005 中有包含两列 Fruit 和 Color 的表,如下所示 Fruit Colour Apple Red Orange
我是一名优秀的程序员,十分优秀!