5

C# Windows アプリケーションには、多くの Excel ワークブックがあります。ワークシートを Excel ワークブックから 1 つのワークブックにコピーしたいのです。これは可能ですが、そのためには Excel ワークブックを開く必要があります。

        Excel.Application app = new Excel.Application();

        app.Visible = true;

        app.WindowState = XlWindowState.xlMinimized;

        app.Workbooks.Add("");
        app.Workbooks.Add(@"Path\WorkBook1.xlsx");
        app.Workbooks.Add(@"Path\WorkBook2.xlsx");

        for (int i = 2; i <= app.Workbooks.Count; i++)
        {
            int count = app.Workbooks[i].Worksheets.Count;

            app.Workbooks[i].Activate();
            for (int j = 1; j <= count; j++)
            {
                Excel._Worksheet ws = (Excel._Worksheet)app.Workbooks[i].Worksheets[j];

                ws.Select(true);
                ws.Cells.Select();

                Excel.Range sel = (Excel.Range)app.Selection;
                sel.Copy(Type.Missing);

                Excel._Worksheet sheet = (Excel._Worksheet)app.Workbooks[1].Worksheets.Add(
                    Type.Missing, Type.Missing, Type.Missing, Type.Missing
                    );

                sheet.Paste(Type.Missing, Type.Missing);

                sheet.Name = app.Workbooks[i].Worksheets[j].Name;
            }


        }

        app.DisplayAlerts = false;
        app.Workbooks[3].Close();
        app.Workbooks[2].Close();
        app.DisplayAlerts = true;

        Cursor = Cursors.Default;

        MessageBox.Show("Successfully Generated Excel...!", "Excel Tool", MessageBoxButtons.OK, MessageBoxIcon.Information);

Excelシートを開かずにすべてのデータをスタイルでコピーすることは可能ですか?

4

1 に答える 1

6

ワークシート自体の内容を選択してコピーせずに、ワークシートとそのすべての内容と書式をコピーするには、Worksheet.Copyを使用できます。次のように使用します。

Excel._Worksheet ws = (Excel._Worksheet)app.Workbooks[i].Worksheets[j];
Excel._Worksheet sheet = (Excel._Worksheet)app.Workbooks[1].Worksheets.Add(
                Type.Missing, Type.Missing, Type.Missing, Type.Missing
                );
ws.Copy(Before: sheet);

ただし、質問が実際に意味するのは、ファイルを開かずにワークブックの内容を 1 つの共通のワークブックにコピーしたいということである場合、それが可能だとは思いません。データにアクセスするには、ファイルを開く必要があります。

于 2013-05-13T04:48:47.340 に答える