由于某些原因,我想将一个 GUID 作为 ID 写入一个文件以保存,并在打开文件之前删除该 ID。
static void Main(string[] args)
{
string id = "b669fd8c904d48e0945c16cac1dc5ed9";
byte[] idbyte = UnicodeEncoding.Default.GetBytes(id);
FileStream input = new FileStream(@"C:\test.xlsx", FileMode.Open, FileAccess.Read);
FileStream output = new FileStream(@"C:\test1.xlsx", FileMode.OpenOrCreate, FileAccess.Write);
CopyStream(input, output);
// add id with byte[] at the end of the file
output.Write(idbyte, 0, idbyte.Length);
output.Close();
input.Close();
FileStream input1 = new FileStream(@"C:\test1.xlsx", FileMode.Open, FileAccess.Read);
FileStream output1 = new FileStream(@"C:\test2.xlsx", FileMode.OpenOrCreate, FileAccess.Write);
int SizeOfBuffer = 1024 * 16;
try
{
byte[] buffer = new byte[SizeOfBuffer];
byte[] bufferLast = new byte[SizeOfBuffer];
int read;
int Nextread;
while ((read = input1.Read(buffer, 0, buffer.Length)) > 0)
{
if ((Nextread = input1.Read(bufferLast, 0, buffer.Length)) > 0)
{
output1.Write(buffer, 0, read);
output1.Write(bufferLast, 0, Nextread);
}
else // delete id with byte[]
{
byte[] buffer2 = new byte[SizeOfBuffer];
for (int i = 0; i < read - idbyte.Length; i++)
{
buffer2[i] = buffer[i];
}
output1.Write(buffer2, 0, buffer2.Length);
break;
}
}
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
}
output1.Close();
input1.Close();
Console.ReadLine();
}
private static void CopyStream(Stream input, Stream output)
{
int SizeOfBuffer = 1024 * 16;
try
{
byte[] buffer = new byte[SizeOfBuffer];
int read;
while ((read = input.Read(buffer, 0, buffer.Length)) > 0)
{
output.Write(buffer, 0, read);
}
}
catch (Exception ex)
{
Console.WriteLine(ex.ToString());
}
}
但是当我打开 C:\test2.xlsx 时,excel 显示错误:“Excel 在 'test2.xlsx' 中发现不可读的内容”!
如何解决这个问题呢 ?