首页 > 解决方案 > 使用标准验证 pt2 导入主数据

问题描述

如何结合这些想法?

if (openFileDialog1.ShowDialog() == DialogResult.OK)
{
    string name = "Sheet1";
    string extension = Path.GetExtension(openFileDialog1.FileName);

        using (System.Data.OleDb.OleDbConnection con = new System.Data.OleDb.OleDbConnection())
        {
            switch (extension)
            {
                case ".xls" :
                    string xlsconStr = @"Provider=Microsoft.Jet.OLEDB.4.0;Data Source='" + openFileDialog1.FileName + "'; Extended Properties=Excel 8.0;";
                    con.ConnectionString = xlsconStr;
                break;

                case ".xlsx":
                    string xlsxconStr = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source='" + openFileDialog1.FileName + "'; Extended Properties=Excel 12.0;";
                    con.ConnectionString = xlsxconStr;
                break;
            }

        using (System.Data.OleDb.OleDbCommand oconn = new System.Data.OleDb.OleDbCommand("SELECT * FROM [" + name + "$]", con))
        {
            con.Open();

            System.Data.OleDb.OleDbDataAdapter adapter = new System.Data.OleDb.OleDbDataAdapter(oconn);
            DataTable data = new DataTable();
            adapter.Fill(data);
            dataGridView1.DataSource = data;
        }
}

和这个

Excel.Application myExcelApp = new Excel.Application();
Excel.Workbooks myExcelWorkbooks;
Excel.Workbook myExcelWorkbook;

myExcelApp.Visible = false;
myExcelWorkbooks = myExcelApp.Workbooks;
string fileName = Convert.ToString("C:\\Users\\ProgrammerPC1\\Desktop\\DLAV FILES\\ACSAD.xls");
myExcelWorkbook = myExcelWorkbooks.Open(fileName);
Excel.Worksheet myExcelWorksheet = (Excel.Worksheet)myExcelWorkbook.ActiveSheet;
            //myExcelWorksheet.Select(Type.Missing);

foreach(Worksheet worksheet in myExcelWorkbook.Worksheets)
{
    listBox1.Items.Add(worksheet.Name);
}

我的想法是删除dataGridView,当我单击按钮(导入)时,它会显示openFileDialog > 选择Excel 文件> 在listView中, excel文件的所有表格都将显示在列表中。

标签: c#excel

解决方案


正如你所说,把它们放在一起!

您需要选择open file dialog零件并将其与以下内容合并for each loop

private string GetFileExcel()
{
    ExcelFileDialog.Filter = "File Excel|*.xls; *.xlsx";
    OpenFileDialog1.InitialDirectory = "C:\\";
    if (OpenFileDialog1.ShowDialog() == DialogResult.OK)
    {
        return OpenFileDialog1.FileName;
    }
}

现在我们在第二个片段中调用它!

Excel.Application myExcelApp = new Excel.Application();
Excel.Workbooks myExcelWorkbooks;
Excel.Workbook myExcelWorkbook;

myExcelApp.Visible = false;
myExcelWorkbooks = myExcelApp.Workbooks;

myExcelWorkbook = myExcelWorkbooks.Open(GetFileExcel()); //We call the new function here, inside the open
Excel.Worksheet myExcelWorksheet = (Excel.Worksheet)myExcelWorkbook.ActiveSheet;

foreach(Worksheet wSheet in myExcelWorkbook.Worksheets)
{
    listBox1.Items.Add(wSheet.Name);
}

现在,当您单击按钮时,它将显示文件对话框,当您选择文件时,它会在列表视图中显示它!


推荐阅读