views:

38

answers:

2

I am trying to import an excel file using asp.net and C#. I found an example in VB, but it is using something called "Server.MapPath" which is not resolving to a namespace. I am on .NET 4.0, C#, and windows XP. I found a "HttpServerUtility.MapPath", but I don't know if this is the equivalent for IIS7?

C#

public OleDbCommand ExcelConnection()        
{                        
    string conStr = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + Server.MapPath("~/ExcelImport.xls") + ";" + "Extended Properties=Excel 8.0;";
    //create your excel connection object using the connection string
    OleDbConnection ocnct = new OleDbConnection(conStr);
    ocnct.Open();

    //use a SQL Select command to retrieve the data from the Excel Spreadsheet
    //the "table name" is the name of the worksheet within the spreadsheet
    //in this case, the worksheet name is "Members" and is coded as: [Members$]
    OleDbCommand ocmd = new OleDbCommand("SELECT * FROM [Members$]", ocnct);
    return ocmd;
}

Online Sample

Protected Function ExcelConnection() As OleDbCommand

' Connect to the Excel Spreadsheet
Dim xConnStr As String = "Provider=Microsoft.Jet.OLEDB.4.0;" & _
            "Data Source=" & Server.MapPath("~/ExcelImport.xls") & ";" & _
            "Extended Properties=Excel 8.0;"

' create your excel connection object using the connection string
Dim objXConn As New OleDbConnection(xConnStr)
objXConn.Open()

' use a SQL Select command to retrieve the data from the Excel Spreadsheet
' the "table name" is the name of the worksheet within the spreadsheet
' in this case, the worksheet name is "Members" and is coded as: [Members$]
Dim objCommand As New OleDbCommand("SELECT * FROM [Members$]", objXConn)
Return objCommand

End Function

+1  A: 

Server.MapPath takes an application relative path (beginning with a ~) and converts it to a full path on disk.
It is a member of the Server object (an instance of the HttpServerUtility class), which can be found on HttpContext and on a page or user control.

If you already haev a full path on disk, you don't need it.

SLaks
+1  A: 

The HttpContext and Page classes both have a property named Server which returns an HttpServerUtility object (in fact, Page just calls return this.Context.Server).

Hence Server.MapPath is HttpServerUtility.MapPath.

It takes a string and computes the file path it would correspond to if that string were a relative URI backed with the out-of-the-box mapping between URIs handled by the application, and the file system (if you've complicated virtual directory mappings it handles that for you) with the added feature that if you begin with a tilde ~ then it considers that to be relative to the application root).

It can fail with values that are neither relative to the application root (begins with ~) or the site root (begins with /) if you've done some remapping along the way, but if you have done some remapping along the way, that's probably not your concern anyway.

Jon Hanna