我需要读取由传统Windows应用程序生成的文件,该应用程序以二进制形式存储实数(8字节“双”类型) - 即作为8字节的打包数组。我可以读取8字节组,但是如何将它呈现给我的ASP JScript代码,这样我就可以重新获得实数。
或换句话说:
假设一个文件是由Windows(Delphi)程序生成的:
Assign (f, 'test.bin') ;
rewrite (f, 1) ;
r := 1234.56E78 ;
BlockWrite (f, r, SizeOf (Double)) ;
Close (f) ;
检查文件将显示它包含8个字节,即:
94 0E 4C CA C2 97 AD 53
这是IEEE格式的实数。假设我可以在ASP中读回这8个字节,是否有一种简单的方法可以重新获得实数?
答案 0 :(得分:1)
在ASP.NET页面中,这可能如下所示:
<%@ Page Language="JScript"
AutoEventWireup="true"
CodeBehind="Default.aspx.cs"
Inherits="WebApplication1._Default" %>
<%
var bytes: byte[] = [0x94, 0x0e, 0x4c, 0xca, 0xc2, 0x97, 0xad, 0x53];
var d = BitConverter.ToDouble(bytes, 0);
Response.Write(d);
%>
哪个可以获得输出:
1.2345678E+95
检查正确性
答案 1 :(得分:1)
感谢Oren的帮助。巴贝奇的东西特别有用。在这里我需要编写的代码(除了规范之外没有经过全面测试):
function ReadFileDouble (Stream)
{
var Bytes0To3 = ReadFileLongword (Stream) ;
var Bytes4To5 = ReadFileWord (Stream) ;
var Bytes6To7 = ReadFileWord (Stream) ;
var Mantissa = Bytes0To3 + (Bytes4To5 * 65536 * 65536) + ((Bytes6To7 & 0x0F) * 65536 * 65536 * 65536) ;
var Fraction = Mantissa / 0x0010000000000000 ;
var Exponent = ((Bytes6To7 >>> 4) & 0x07FF) ;
var SignBit = ((Bytes6To7 & 0x8000) != 0) ;
if (SignBit)
{
Sign = -1 ;
}
else
{
Sign = +1 ;
}
var Bias = 1023 ;
if (Exponent == 0)
{
if (Mantissa == 0)
{
return (0.00 * Sign) ;
}
else
{
return ((Fraction * (Math.pow (2.0, - Bias + 1))) * Sign) ;
}
}
else if (Exponent == 1023)
{
if (Mantissa == 0)
{
return (Number.POSITIVE_INFINITY * Sign) ;
}
else if (Mantissa < 0x0008000000000000)
{
return (Number.NaN * Sign) ;
}
else
{
return (Number.NaN * Sign) ;
}
}
else
{
return ((1.0 + Fraction) * (Math.pow (2.0, Exponent - Bias)) * Sign) ;
}
}
答案 2 :(得分:0)
您可以使用ADO流。它用于读取,写入和管理二进制数据或文本流。
Dim objStream As ADODB.Stream
objStream.Type = 1
objStream.LoadFromFile path
Dim Number : Number = BytesToNumEx(objStream.Read 8, 1, 8, False)
您需要以下功能:
Function BytesToNumEx(ByteArray(), StartRec, EndRec, UnSigned)
Dim i
Dim lng256 : lng256 = 1
Dim lngReturn : lngReturn = 0
If EndRec < 1 Then
EndRec = UBound(ByteArray)
End If
If StartRec > EndRec Or StartRec < 0 Then
BytesToNumEx = -1
Exit Function
End If
lngReturn = lngReturn + (ByteArray(StartRec))
For i = (StartRec + 1) To EndRec
lng256 = lng256 * 256
If i < EndRec Then
lngReturn = lngReturn + (ByteArray(i) * lng256)
Else
If ByteArray(i) > 127 And UnSigned = False Then
lngReturn = (lngReturn + ((ByteArray(i) - 256) * lng256))
Else
lngReturn = lngReturn + (ByteArray(i) * lng256)
End If
End If
Next
BytesToNumEx = lngReturn
End Function