Copy codeThe Code is as follows:
/// <Summary>
/// Export the data in the datatable to the specified excel File
/// </Summary>
/// <Param name = "page"> web page Object </param>
/// <Param name = "tab"> datatable object containing exported data </param>
/// <Param name = "filename"> name of the excel file </param>
Public static void export (system. web. ui. page, system. data. datatable tab, string filename)
{
System. web. httpresponse = page. response;
System. web. ui. webcontrols. datagrid = new system. web. ui. webcontrols. datagrid ();
Datagrid. datasource = tab. defaultview;
Datagrid. allowpaging = false;
Datagrid. headerstyle. backcolor = system. drawing. color. green;
Datagrid. headerstyle. horizontalalign = horizontalalign. center;
Datagrid. headerstyle. font. bold = true;
Datagrid. databind ();
Httpresponse. appendheader ("content-disposition", "attachment; filename =" + httputility. urlencode (filename, system. text. encoding. utf8); // filename = "*. xls ";
Httpresponse. contentencoding = system. text. encoding. getencoding ("gb2312 ");
Httpresponse. contenttype = "application/ms-excel ";
System. io. stringwriter tw = new system. io. stringwriter ();
System.web.ui.html textwriter hw = new system.web.ui.html textwriter (tw );
Datagrid. rendercontrol (hw );
String filepath = page. server. mappath ("..") + "\ files \" + filename;
System. io. streamwriter sw = system. io. file. createtext (filepath );
Sw. write (tw. tostring ());
Sw. close ();
Downfile (httpresponse, filename, filepath );
Httpresponse. end ();
}
Private static bool downfile (system. web. httpresponse response, string filename, string fullpath)
{
Try
{
Response. contenttype = "application/octet-stream ";
Response. appendheader ("content-disposition", "attachment; filename =" +
Httputility. urlencode (filename, system. text. encoding. utf8) + "; charset = gb2312 ");
System. io. filestream fs = system. io. file. openread (fullpath );
Long flen = fs. length;
Int size = 102400; // download data at the same time every k
Byte [] readdata = new byte [size]; // specify the buffer size
If (size> flen) size = convert. toint32 (flen );
Long fpos = 0;
Bool isend = false;
While (! Isend)
{
If (fpos + size)> flen)
{
Size = convert. toint32 (flen-fpos );
Readdata = new byte [size];
Isend = true;
}
Fs. read (readdata, 0, size); // read a compressed Block
Response. binarywrite (readdata );
Fpos + = size;
}
Fs. close ();
System. io. file. delete (fullpath );
Return true;
}
Catch
{
Return false;
}
}
/// <Summary>
/// Convert the data in the specified excel file into a able object for further processing by the program
/// </Summary>
/// <Param name = "filepath"> </param>
/// <Returns> </returns>
Public static system. data. datatable import (string filepath)
{
System. data. datatable rs = new system. data. datatable ();
Bool canopen = false;
Oledbconnection conn = new oledbconnection ("provider = microsoft. jet. oledb.4.0;" +
"Data source =" + filepath + ";" +
"Extended properties = \" excel 8.0 ;\"");
Try // try whether the data connection is available
{
Conn. open ();
Conn. close ();
Canopen = true;
}
Catch {}
If (canopen)
{
Try // if the data connection can be opened, try to read the data
{
Oledbcommand myoledbcommand = new oledbcommand ("select * from [sheet1 $]", conn );
Oledbdataadapter mydata = new oledbdataadapter (myoledbcommand );
Mydata. fill (rs );
Conn. close ();
}
Catch // if the data connection can be opened but Data Reading fails, extract the worksheet name from the file and then read the data
{
String sheetname = getsheetname (filepath );
If (sheetname. length> 0)
{
Oledbcommand myoledbcommand = new oledbcommand ("select * from [" + sheetname + "$]", conn );
Oledbdataadapter mydata = new oledbdataadapter (myoledbcommand );
Mydata. fill (rs );
Conn. close ();
}
}
}
Else
{
System. io. streamreader tmpstream = file. opentext (filepath );
String tmpstr = tmpstream. readtoend ();
Tmpstream. close ();
Rs = getdatatablefromstring (tmpstr );
Tmpstr = "";
}
Return rs;
}
/// <Summary>
/// Convert the data of the specified html string to a able object. The data is processed based on special characters such as <tr> <td>.
/// </Summary>
/// <Param name = "tmphtml"> html string </param>
/// <Returns> </returns>
Private static datatable getdatatablefromstring (string tmphtml)
{
String tmpstr = tmphtml;
Datatable tb = new datatable ();
// Process the string and delete the part after the first <tr> is merged with the last </tr>.
Int index = tmpstr. indexof ("<tr ");
If (index>-1)
Tmpstr = tmpstr. substring (index );
Else
Return tb;
Index = tmpstr. lastindexof ("</tr> ");
If (index>-1)
Tmpstr = tmpstr. substring (0, index + 5 );
Else
Return tb;
Bool existssparator = false;
Char separator = convert. tochar ("^ ");
// If the original string contains the separator "^", replace it
If (tmpstr. indexof (separator. tostring ()>-1)
{
Existssparator = true;
Tmpstr = tmpstr. replace ("^", "^ $ & ^ ");
}
// Split the Image Based on "</tr>"
String [] tmprow = tmpstr. replace ("</tr>", "^"). split (separator );
For (int I = 0; I <tmprow. length-1; I ++)
{
Datarow newrow = tb. newrow ();
String tmpstri = tmprow [I];
If (tmpstri. indexof ("<tr")>-1)
{
Tmpstri = tmpstri. substring (tmpstri. indexof ("<tr "));
If (tmpstri. indexof ("display: none") <0 | tmpstri. indexof ("display: none")> tmpstri. indexof ("> "))
{
Tmpstri = tmpstri. replace ("</td>", "^ ");
String [] tmpfield = tmpstri. split (separator );
For (int j = 0; j <tmpfield. length-1; j ++)
{
Tmpfield [j] = removestring (tmpfield [j], "<font> ");
Index = tmpfield [j]. lastindexof (">") + 1;
If (index> 0)
{
String field = tmpfield [j]. substring (index, tmpfield [j]. length-index );
If (existssparator) field = field. replace ("^ $ & ^", "^ ");
If (I = 0)
{
String tmpfieldname = field;
Int sn = 1;
While (tb. columns. contains (tmpfieldname ))
{
Tmpfieldname = field + sn. tostring ();
Sn + = 1;
}
Tb. columns. add (tmpfieldname );
}
Else
{
Newrow [j] = field;
}
} // End of if (index> 0)
}
If (I> 0)
Tb. rows. add (newrow );
}
}
}
Tb. acceptchanges ();
Return tb;
}
/// <Summary>
/// Remove the specified object from the specified html string
/// </Summary>
/// <Param name = "tmphtml"> html string </param>
/// <Param name = "remove"> objects to be excluded-for example, input "<font>" to remove "<font ???> "And" </font> "</param>
/// <Returns> </returns>
Public static string removestring (string tmphtml, string remove)
{
Tmphtml = tmphtml. replace (remove. replace ("<", "</"),"");
Tmphtml = removestringhead (tmphtml, remove );
Return tmphtml;
}
/// <Summary>
/// Only used by the removestring () method
/// </Summary>
/// <Returns> </returns>
Private static string removestringhead (string tmphtml, string remove)
{
// For convenience of annotation, assume that the input parameter remove = "<font>"
If (remove. length <1) return tmphtml; // The parameter remove is null: no processing is returned.
If (remove. substring (0, 1 )! = "<") | (Remove. substring (remove. length-1 )! = ">") Return tmphtml; // The parameter remove is not <???> : Do not process returned results
Int indexs = tmphtml. indexof (remove. replace (">", ""); // find the location of "<font"
Int indexe =-1;
If (indexs>-1)
{
String tmpright = tmphtml. substring (indexs, tmphtml. length-indexs );
Indexe = tmpright. indexof ("> ");
If (indexe>-1)
Tmphtml = tmphtml. substring (0, indexs) + tmphtml. substring (indexs + indexe + 1 );
If (tmphtml. indexof (remove. replace (">", "")>-1)
Tmphtml = removestringhead (tmphtml, remove );
}
Return tmphtml;
}
/// <Summary>
/// Read the name of the first worksheet from the specified excel File
/// </Summary>
/// <Param name = "filepath"> </param>
/// <Returns> </returns>
Private static string getsheetname (string filepath)
{
String sheetname = "";
System. io. filestream tmpstream = file. openread (filepath );
Byte [] filebyte = new byte [tmpstream. length];
Tmpstream. read (filebyte, 0, filebyte. length );
Tmpstream. close ();
Byte [] tmpbyte = new byte [] {convert. tobyte (11), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0 ),
Convert. tobyte (11), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0), convert. tobyte (0 ),
Convert. tobyte (30), convert. tobyte (16), convert. tobyte (0), convert. tobyte (0 )};
Int index = getsheetindex (filebyte, tmpbyte );
If (index>-1)
{
Index + = 16 + 12;
System. collections. arraylist sheetnamelist = new system. collections. arraylist ();
For (int I = index; I <filebyte. length-1; I ++)
{
Byte temp = filebyte [I];
If (temp! = Convert. tobyte (0 ))
Sheetnamelist. add (temp );
Else
Break;
}
Byte [] sheetnamebyte = new byte [sheetnamelist. count];
For (int I = 0; I <sheetnamelist. count; I ++)
Sheetnamebyte [I] = convert. tobyte (sheetnamelist [I]);
Sheetname = system. text. encoding. default. getstring (sheetnamebyte );
}
Return sheetname;
}
/// <Summary>
/// Only used by the getsheetname () method
/// </Summary>
/// <Returns> </returns>
Private static int getsheetindex (byte [] findtarget, byte [] finditem)
{
Int index =-1;
Int finditemlength = finditem. length;
If (finditemlength <1) return-1;
Int findtargetlength = findtarget. length;
If (findtargetlength-1) <finditemlength) return-1;
For (int I = findtargetlength-finditemlength-1; I>-1; I --)
{
System. collections. arraylist tmplist = new system. collections. arraylist ();
Int find = 0;
For (int j = 0; j <finditemlength; j ++)
{
If (findtarget [I + j] = finditem [j]) find + = 1;
}
If (find = finditemlength)
{
Index = I;
Break;
}
}
Return index;
}