アプリケーションで優れたデータテーブルをエクスポートしようとしています。しかし、私のデータテーブルは 220 万件以上のレコードで構成されており、Excel には 65536 レコードしか書き込めません。
Google でよく検索した結果、2007 年より前のバージョンの Excel には 65536 レコードしか書き込めないことがわかりました。
65536 を超えるレコードを Excel に書き込むことができる場合は、お知らせください
アプリケーションで Microsoft Office lib を使用していません。Excel にテーブルを書き込む独自のクラスを使用しています。
ここに私のExcelクラスがあります
public class ExcelWrite { プライベート ストリーム ストリーム; プライベート BinaryWriter ライター。
private ushort[] clBegin = { 0x0809, 8, 0, 0x10, 0, 0 };
private ushort[] clEnd = { 0x0A, 00 };
private void WriteUshortArray(ushort[] value)
{
for (int i = 0; i < value.Length; i++)
writer.Write(value[i]);
}
/// <summary>
/// Initializes a new instance of the <see cref="ExcelWriter"/> class.
/// </summary>
/// <param name="stream">The stream.</param>
public ExcelWrite(Stream stream)
{
this.stream = stream;
writer = new BinaryWriter(stream);
}
public ExcelWrite()
{
}
/// <summary>
/// Writes the text cell value.
/// </summary>
/// <param name="row">The row.</param>
/// <param name="col">The col.</param>
/// <param name="value">The string value.</param>
public void WriteCell(int row, int col, string value)
{
ushort[] clData = { 0x0204, 0, 0, 0, 0, 0 };
int iLen = value.Length;
byte[] plainText = Encoding.ASCII.GetBytes(value);
clData[1] = (ushort)(8 + iLen);
clData[2] = (ushort)row;
clData[3] = (ushort)col;
clData[5] = (ushort)iLen;
WriteUshortArray(clData);
writer.Write(plainText);
}
/// <summary>
/// Writes the integer cell value.
/// </summary>
/// <param name="row">The row number.</param>
/// <param name="col">The column number.</param>
/// <param name="value">The value.</param>
public void WriteCell(int row, int col, int value)
{
ushort[] clData = { 0x027E, 10, 0, 0, 0 };
clData[2] = (ushort)row;
clData[3] = (ushort)col;
WriteUshortArray(clData);
int iValue = (value << 2) | 2;
writer.Write(iValue);
}
/// <summary>
/// Writes the double cell value.
/// </summary>
/// <param name="row">The row number.</param>
/// <param name="col">The column number.</param>
/// <param name="value">The value.</param>
public void WriteCell(int row, int col, double value)
{
ushort[] clData = { 0x0203, 14, 0, 0, 0 };
clData[2] = (ushort)row;
clData[3] = (ushort)col;
WriteUshortArray(clData);
writer.Write(value);
}
/// <summary>
/// Writes the empty cell.
/// </summary>
/// <param name="row">The row number.</param>
/// <param name="col">The column number.</param>
public void WriteCell(int row, int col)
{
ushort[] clData = { 0x0201, 6, 0, 0, 0x17 };
clData[2] = (ushort)row;
clData[3] = (ushort)col;
WriteUshortArray(clData);
}
/// <summary>
/// Must be called once for creating XLS file header
/// </summary>
public void BeginWrite()
{
WriteUshortArray(clBegin);
}
/// <summary>
/// Ends the writing operation, but do not close the stream
/// </summary>
public void EndWrite()
{
WriteUshortArray(clEnd);
writer.Flush();
}
public void exporttoExcel(DataTable table,string filename)
{
DataTable dt = new DataTable();
try
{
StringBuilder SB = new StringBuilder();
dt = table;
if (dt.Rows.Count > 0)
{
FileStream stream = File.Open("C:/Application/" + filename + ".xls", FileMode.Create);
ExcelWrite excelWriter = new ExcelWrite(stream);
//AB_MISreports.Util.ExcelWrite excelWriter = new AB_MISreports.Util.ExcelWrite(stream);
excelWriter.BeginWrite();
for (int i = 0; i < dt.Columns.Count; i++)
{
excelWriter.WriteCell(0, i, dt.Columns[i].ColumnName.ToString());
for (int j = 0; j < dt.Rows.Count; j++)
{
excelWriter.WriteCell(j + 1, i, dt.Rows[j][i].ToString());
}
}
excelWriter.EndWrite();
stream.Close();
HttpContext.Current.Response.ContentType = "application/vnd.xls";
HttpContext.Current.Response.AddHeader("content-disposition", "attachment; filename=" + filename + ".xls");
HttpContext.Current.Response.TransmitFile("C:/Application/" + filename + ".xls");
HttpContext.Current.Response.End();
HttpContext.Current.Response.Flush();
}
}
catch (Exception ex)
{
throw ex;
}
finally
{
dt.Dispose();
}
}
}