5

Excelファイルからmssqlデータベースにデータをインポートするアプリケーションを実行するには、サーバーにMicrosoft Officeをインストールする必要がありますか?

何か提案やアイデアはありますか?

私が使用したコード

public partial class _Default : System.Web.UI.Page
{
private String strConnection = "Data Source=MYCBJ017550027;Initial Catalog=MySamplesDB;Integrated Security=True";
protected void Page_Load(object sender, EventArgs e)
{

}
protected void btnSend_Click(object sender, EventArgs e)
{
string path = fileuploadExcel.PostedFile.FileName;
string excelConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties=Excel 12.0;Persist Security Info=False";
OleDbConnection excelConnection =new OleDbConnection(excelConnectionString);
OleDbCommand cmd = new OleDbCommand("Select [ID],[Name],[Designation] from [Sheet1$]",excelConnection);
excelConnection.Open();
OleDbDataReader dReader;
dReader = cmd.ExecuteReader();
SqlBulkCopy sqlBulk = new SqlBulkCopy(strConnection);
sqlBulk.DestinationTableName = "Excel_table";
sqlBulk.WriteToServer(dReader);
excelConnection.Close();
}
}
4

3 に答える 3

8

xlsファイルのみを読み取る場合はMicrosoft.Jet.OLEDB.4.0、.netフレームワークに組み込まれているファイルを使用してください。

xlsxファイルを読み取る場合は、を使用してMicrosoft.ACE.OLEDB.12.0ください。このためのドライバは、Microsoftサイトから無料でダウンロードできます。相互運用のためにMicrosoftOfficerをインストールする必要はありません。

次の接続文字列を使用します

    string excelConnectionString = @"Provider=Microsoft.ACE.OLEDB.12.0;  
Data Source=" + path + ";Extended Properties=Excel 12.0;HDR=YES";

ここからドライバーをダウンロードします

実行例についてはこれを参照してください

于 2012-05-22T13:18:25.023 に答える
2

@Romilが言ったように、そのために.NETフレームワークを使用できます。

string ConnectionString = string.Format(@"Provider=Microsoft.Jet.OLEDB.4.0; Data Source={0}; Extended Properties=""Excel 8.0;HDR=Yes"";", fileName);

using (OleDbConnection conn = new OleDbConnection(ConnectionString))
{
     conn.Open();
     DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });

     foreach (DataRow schemaRow in schemaTable.Rows)
     {
          string sheet = schemaRow["TABLE_NAME"].ToString();
          using (OleDbCommand cmd = new OleDbCommand("SELECT * FROM [" + sheet + "]", conn))
          {
               cmd.CommandType = CommandType.Text;
               DataTable outputTable = new DataTable(sheet);
               output.Tables.Add(outputTable);
               new OleDbDataAdapter(cmd).Fill(outputTable);
          }
     }
                conn.Close();
}
于 2012-05-22T13:22:06.407 に答える
0

jetの問題は、それでもデータプロバイダーをインストールする必要があるか(これも無料ですが)、それを機能させるためにOfficeをインストールする必要があることです。単にExcelファイルを読み取る必要がある場合は、何もインストールしなくてもトラックを正常に実行できる、完全に管理されたライブラリがたくさんあります。

ここにいくつかリストしました。私はexcelreaderをたくさん使用しましたが、良い結果が得られました。

http://excelreader.codeplex.com/
http://epplus.codeplex.com/

Excelリーダーは、ドキュメントの面で軽いようです。これがその使い方の例です

IExcelDataReader reader = null;
try
{
    using (FileStream stream = new FileStream(ofd.FileName, FileMode.Open))
    {
        string ext = System.IO.Path.GetExtension(ofd.FileName).Replace(".", "").ToUpper();
        if (ext == "XLS")
            reader = ExcelReaderFactory.CreateBinaryReader(stream);
        else
            reader = ExcelReaderFactory.CreateOpenXmlReader(stream);

        reader.IsFirstRowAsColumnNames = true;
        using (DataSet ds = reader.AsDataSet())
        {
            foreach (DataRow dr in ds.Tables[0].Rows)
            {
                ImportData toAdd = new ImportData()
                    {
                        Format = dr[0].ToString(),
                    };

                Database.Datastore.InsertObject(toAdd);
            }
        }
    }
}
于 2012-05-22T13:31:59.457 に答える