0

アプリケーションで優れたデータテーブルをエクスポートしようとしています。しかし、私のデータテーブルは 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();
        }

    }
}
4

2 に答える 2

3

これらは公式の制限です。Excel 2007 は .xls と .xlsx の両方の形式のファイルをサポートしていますが、新しいファイル形式のファイルを書き込んでいますか? 実行可能なオプションではないかもしれませんが、Aspose.Cellsを使用してスプレッドシートの作成を処理します。

Excel 2003 .xls - 65,536 行
( http://office.microsoft.com/en-gb/excel-help/excel-specifications-and-limits-HP005199291.aspx )

Excel 2007 .xlsx - 1,048,576 行
( http://office.microsoft.com/en-gb/excel-help/excel-specifications-and-limits-HP010073849.aspx )

Excel 2010 .xlsx - 1,058,576 行
( http://office.microsoft.com/en-gb/excel-help/excel-specifications-and-limits-HP010342495.aspx )

于 2013-03-20T07:36:47.377 に答える
0

フォーマット形式を ".xls" から ".xlsx" に変更してみてください FileStream stream = File.Open("C:/Application/" + filename + ".xlsx", FileMode.Create);

于 2013-04-27T05:26:59.843 に答える