怎么把System.data.DataTable 里的数据导入到Excel表格里呢?

请问怎么把Datatable里的数据导出到Excel里的表格里,我导出的只有一行是什么原因呢?

3个回答

遍历,然后自己通过微软提供的dll去写入到excel文件,或者用NPOI,这个挺好用的

楼主使用的导出代码是什么?建议详细描述一下。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
OleDbDataAdapter.fill四舍五入数据的问题
请教各位大神 需求:将EXCEL表格导入到开发软件中,其中有一个字段数值26.525在EXCEL中四舍五入,并且已经显示为26.53,但是为什么将此表格填充到数据集中,该字段数值变为26.52。 附源代码 string strCon = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + strFileName + ";Extended Properties='Excel 12.0;HDR=No;IMEX=1'"; System.Data.OleDb.OleDbConnection myConn = new System.Data.OleDb.OleDbConnection(strCon); myConn.Open(); DataTable dt = myConn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null); string strSheetName = dt.Rows[0]["TABLE_NAME"].ToString(); string strCom = "SELECT * FROM [" + strSheetName + "]"; System.Data.OleDb.OleDbDataAdapter myCommand = new System.Data.OleDb.OleDbDataAdapter(strCom, myConn); //创建一个DataSet对象 DataSet myDataSet = new DataSet(); //得到自己的DataSet对象 myCommand.Fill(myDataSet); //关闭此数据链接 myConn.Close(); return myDataSet;
oledb connection出错
使用vs2010用c#写一段代码目的是把csv文件导入datagridview中 网上看到的代码string conString = "Provider=Microsoft.ACE.OLEDB.12.0; Data Source=" + fileName + ";Extended Properties='Excel 12.0;HDR=YES;IMEX=1'";这一段代码他是什么意思后面进行定义using (OleDbConnection con = new OleDbConnection(conString)) { con.Open(); System.Data.DataTable dt1 = con.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null); string tableName = dt1.Rows[0]["Table_Name"].ToString(); string sql = "select * from [" + tableName + "]"; OleDbDataAdapter da = new OleDbDataAdapter(sql, con); System.Data.DataTable dt = new System.Data.DataTable(); da.Fill(dt); dataGridView1.DataSource = dt; //BindGrid(dt); con.Close();但是测试的时候出错 ,cn 写的是外部表不是预期的格式 这是什么问题???求大神 急 加分
asp导入excel表的时候,外部表不是预期格式
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using System.Data; using System.Data.OleDb; public partial class _Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { string asd = "C:\\Users\\owlcity33\\Desktop\\222.xlsx"; DataSet ds = ExcelToDS(asd); DataTable dt = ds.Tables[0]; GridView1.DataSource = dt; GridView1.DataBind(); } public DataSet ExcelToDS(string Path) { string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Path + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; OleDbConnection conn = new OleDbConnection(strConn); conn.Open(); string strExcel = ""; OleDbDataAdapter myCommand = null; DataSet ds = null; strExcel = "select * from [sheet1$]"; myCommand = new OleDbDataAdapter(strExcel,strConn); ds = new DataSet(); myCommand.Fill(ds, "table1"); return ds; } protected void Button1_Click(object sender, EventArgs e) { string PH = FileUpload1.PostedFile.FileName.ToString(); DataSet ds1= ExcelToDS(PH); DataTable dt1 = ds1.Tables[0]; g.DataSource = dt1; g.DataBind(); } }
c# winform excel导入sqlite数据库,求代码
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Linq; using System.Windows.Forms; using DevExpress.XtraEditors; using System.Data.OleDb; using TenderClear.Common; using TenderClear.BLL.TC01; namespace TenderClear.UI.Forms.TC01 { public partial class TC010103Form : DevExpress.XtraEditors.XtraForm { public TC010103Form() { InitializeComponent(); } DataTable dt = new DataTable(); DataGridView dgv=new DataGridView(); private void txtExcel_Click(object sender, EventArgs e) { //打开excel选择框 OpenFileDialog frm = new OpenFileDialog(); frm.Filter = "Excel文件(*.xls,xlsx)|*.xls;*.xlsx"; if (frm.ShowDialog() == DialogResult.OK) { txtExcel.Text = frm.FileName; bind(txtExcel.Text); } } private void bind(string fileName) { string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + "Extended Properties=Excel 8.0;"; OleDbDataAdapter da = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", strConn); DataSet ds = new DataSet(); try { da.Fill(ds); dt = ds.Tables[0]; this.dgv.DataSource = dt; } catch (Exception err) { MessageBox.Show("操作失败!" + err.ToString()); } } private void simpleButton2_Click(object sender, EventArgs e) { if (dgv.Rows.Count > 0) { DataRow dr = null; for (int i = 0; i < dt.Rows.Count; i++) { dr = dt.Rows[i]; insertToSql(dr); } MessageBox.Show("导入成功!"); } else { MessageBox.Show("没有数据!"); } } private void insertToSql(DataRow dr) { //excel表中的列名和数据库中的列名一定要对应 string xmlx = dr["XMLX"].ToString(); string xmbm = dr["XMXM"].ToString(); string xmmc = dr["XMMC"].ToString(); string xmdw = dr["XMDW"].ToString(); string dydj = dr["DYDJ"].ToString(); string zyxf = dr["ZYXF"].ToString(); string xmnr = dr["XMNR"].ToString(); DateTime kssj = Convert.ToDateTime(dr["KSSJ"].ToString()); DateTime jssj = Convert.ToDateTime(dr["JSSJ"].ToString()); int count=BLL10101.InsertOrUpdate(xmlx,xmbm,xmmc,xmdw,dydj,zyxf,xmnr,kssj,jssj); } } } 以上是我在网上找的代码,但是有出现错误,求大神们看看。![图片说明](https://img-ask.csdn.net/upload/201703/30/1490860056_295176.png)
C#导入execl到datagridview遇到问题,求帮忙解决,万分感谢!
问题源码如下:运行后提示错误009,也就是说,出错代码是comm.Fill(ds, "table1");这条。 求解决 ``` public void getExcel(DataGridView dgv, System.Windows.Forms.Label lbl) { OpenFileDialog open = new OpenFileDialog(); open.Title = "请选择要导入的Excel文件"; open.Filter = "Excel文件(*.xls)|*.xls"; if (open.ShowDialog() == DialogResult.OK) { string fileName = open.FileName; //根据路径打开一个Excel文件并将数据填充到DataSet中   string strConn = @"Provider = Microsoft.Jet.OLEDB.4.0; Data Source = " + fileName + "; extended properties = 'Excel 8.0;HDR=NO;IMEX=1;'";//导入时包含Excel中的第一行数据,并且将数字和字符混合的单元格视为文本进行导入   OleDbConnection conn = new OleDbConnection(strConn); conn.Open(); string strExcel = "select  * from   [sheet1$]"; OleDbDataAdapter comm = new OleDbDataAdapter(strExcel, strConn); DataSet ds = new DataSet(); try { comm.Fill(ds, "table1"); } catch { MessageBox.Show("错误信息:009", "错误"); return; } comm.Fill(ds, "table1"); //根据DataGridView的列构造一个新的DataTable   System.Data.DataTable dt = new System.Data.DataTable(); System.Data.DataTable dt2 = new System.Data.DataTable(); foreach (DataGridViewColumn dgvc in dgv.Columns) { if (dgvc.Visible) { DataColumn dc = new DataColumn(); dc.ColumnName = dgvc.DataPropertyName; dt.Columns.Add(dc); DataColumn dc2 = new DataColumn(); dc2.ColumnName = dgvc.DataPropertyName; dt2.Columns.Add(dc2); if (dgvc.CellType == typeof(DataGridViewCheckBoxCell)) { dc2.DataType = Type.GetType("System.Boolean"); } } } //根据Excel的行逐一对上面构造的DataTable的列进行赋值   foreach (DataRow excelRow in ds.Tables[0].Rows) { int i = 0; DataRow dr = dt.NewRow(); foreach (DataColumn dc in dt.Columns) { dr[dc] = excelRow[i]; i++; } dt.Rows.Add(dr); } //判断Excel的格式是否正确   int n = 0; for (int j = 0; j < dt.Columns.Count; j++) { bool flag = false; for (int k = n; k < dgv.ColumnCount; k++) { if (dgv.Columns[k].Visible) //隐藏的列   { if (dgv.Columns[k].HeaderText.Trim().ToString() == dt.Rows[0][j].ToString()) { if (dgv.Columns[k].CellType == typeof(DataGridViewCheckBoxCell)) { //list.Add(j);   //num++;   } flag = true; n = k + 1; break; } } } if (flag == false) { MessageBox.Show("导入的Excel的格式错误", "提示"); return; } } //删除多余的行   int rowCount = (dt.Rows.Count) / 2; for (int i = 0; i <= rowCount; i++) { dt.Rows.RemoveAt(0); } //处理Boolean类型的数据   for (int i = 0; i < dt.Rows.Count; i++) { DataRow dr = dt2.NewRow(); for (int j = 0; j < dt.Columns.Count; j++) { try { dr[j] = dt.Rows[i][j]; } catch { dr[j] = false; } } dt2.Rows.Add(dr); } //导入到dataGridView   dgv.DataSource = dt2; lbl.Text = dgv.RowCount.ToString(); } else { MessageBox.Show("导入excel文件失败"); return; } MessageBox.Show("导入excel文件成功。"); ```
NPOI导入EXCEL,请解决下错误问题!!!
.aspx文件 ``` <%@ Page Language="C#" AutoEventWireup="true" CodeFile="NPOIcheshi.aspx.cs" Inherits="NPOIcheshi" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>无标题页</title> </head> <body> <form id="form1" runat="server"> <div> <asp:FileUpload ID="ExcelFileUpload" runat="server" />&nbsp;&nbsp;&nbsp;&nbsp;<asp:Button runat="server" ID="scBtn" Text="上传" OnClick="scBtn_Click" />&nbsp;&nbsp;&nbsp;&nbsp;<asp:Label runat="server" ID="labelrow" Text="5"></asp:Label></div> <div> <br /> <br /> <br /> <asp:GridView ID="GridView1" runat="server"> </asp:GridView> </div> </form> </body> </html> ``` .CS文件 ``` using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; public partial class NPOIcheshi : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { } private string fileName = null; //文件名 private IWorkbook workbook = null; private FileStream fs = null; private bool disposed; /// <summary> /// 将excel中的数据导入到DataTable中 /// </summary> /// <param name="sheetName">excel工作薄sheet的名称</param> /// <param name="isFirstRowColumn">第一行是否是DataTable的列名</param> /// <returns>返回的DataTable</returns> public DataTable ExcelToDataTable(string sheetName, bool isFirstRowColumn) { ISheet sheet = null; DataTable data = new DataTable(); int startRow = 0; try { fs = new FileStream(fileName, FileMode.Open, FileAccess.Read); //if (fileName.IndexOf(".xlsx") > 0) // 2007版本 // workbook = new XSSFWorkbook(fs); //else if (fileName.IndexOf(".xls") > 0) // 2003版本 workbook = new HSSFWorkbook(fs); if (sheetName != null) { sheet = workbook.GetSheet(sheetName); if (sheet == null) //如果没有找到指定的sheetName对应的sheet,则尝试获取第一个sheet { sheet = workbook.GetSheetAt(0); } } else { sheet = workbook.GetSheetAt(0); } if (sheet != null) { IRow firstRow = sheet.GetRow(0); int cellCount = firstRow.LastCellNum; //一行最后一个cell的编号 即总的列数 if (isFirstRowColumn) { for (int i = firstRow.FirstCellNum; i < cellCount; ++i) { ICell cell = firstRow.GetCell(i); if (cell != null) { string cellValue = cell.StringCellValue; if (cellValue != null) { DataColumn column = new DataColumn(cellValue); data.Columns.Add(column); } } } startRow = sheet.FirstRowNum + 1; } else { startRow = sheet.FirstRowNum; } //最后一列的标号 int rowCount = sheet.LastRowNum; for (int i = startRow; i <= rowCount; ++i) { IRow row = sheet.GetRow(i); if (row == null) continue; //没有数据的行默认是null        DataRow dataRow = data.NewRow(); for (int j = row.FirstCellNum; j < cellCount; ++j) { if (row.GetCell(j) != null) //同理,没有数据的单元格都默认是null dataRow[j] = row.GetCell(j).ToString(); } data.Rows.Add(dataRow); } } return data; } catch (Exception ex) { Console.WriteLine("Exception: " + ex.Message); return null; } } public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (!this.disposed) { if (disposing) { if (fs != null) fs.Close(); } fs = null; disposed = true; } } protected void scBtn_Click(object sender, EventArgs e) { fileName = ExcelFileUpload.FileName.ToString(); disposed = true; DataTable dataTable = new DataTable(); dataTable = ExcelToDataTable("sheet1", true); labelrow.Text = dataTable.Rows.Count.ToString(); GridView1.DataSource = dataTable; GridView1.DataBind(); } } ``` 现在的错误是: 未将对象引用设置到对象的实例 行 138: labelrow.Text = dataTable.Rows.Count.ToString();
C#中使用Nopi导入EXCEL表格,只是更改了一下表头,再导出时excel表格的大小变大好几倍?
比如: 导入一个130k的表格,在c#中将其转为datatable后,更改了一下表头和某些少量数据。但并未增加数据!然后再将datatable转为excel表格并导出时。新表格的大小为890k. 注意:1.检查过没有隐藏的对象。 2.表格的单元格大小前后一致。 恳请大佬帮忙解决一下: ``` /// 导出Excel /// </summary> /// <param name="SourceTable">导出的数据源</param> /// <param name="page">WEB页面对象,默认传Page,只可WEB后台调用</param> /// <param name="type">WEB页面值,如果是素金则另作处理</param> /// <returns></returns> public void ExportExcel(DataTable ds, DataTable dtt, Page page, string type) { DataTable dt = ds; string basePath = page.Server.MapPath("."); //如果目录不存在,则创建目录 if (!Directory.Exists(basePath)) { Directory.CreateDirectory(basePath); } string filePath = string.Empty; string fileName = string.Empty; //filePath = page.Server.MapPath(".") + "\\" + fileName + ".xls"; // filePath = page.Server.MapPath(".") + "\\" + System.DateTime.Now.ToString("yyyyMMddHHmmss") + ".xls"; MemoryStream ms; if (type == "素金") { fileName = System.DateTime.Now.ToString("yyyyMMddHHmmss"); ms = RenderDataTableToExcelSujin(dt, page) as MemoryStream; } else { if (ds.Rows.Count > 0) { if (ds.Rows[0]["采购订单号"].ToString().Trim().Length != 0) { fileName = ds.Rows[0]["采购订单号"].ToString().Trim(); } else { fileName = System.DateTime.Now.ToString("yyyyMMddHHmmss"); } } else { fileName = System.DateTime.Now.ToString("yyyyMMddHHmmss"); } ms = RenderDataTableToExcel(dt, dtt, page) as MemoryStream; } FileStream fs; //FileStream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write); try { filePath = page.Server.MapPath(".") + "\\" + fileName + ".xls"; fs = new FileStream(filePath, FileMode.Create, FileAccess.Write); } catch (Exception) { fileName = System.DateTime.Now.ToString("yyyyMMddHHmmss"); filePath = page.Server.MapPath(".") + "\\" + fileName + ".xls"; fs = new FileStream(page.Server.MapPath(".") + "\\" + fileName + ".xls", FileMode.Create, FileAccess.Write); } byte[] data = ms.ToArray(); fs.Write(data, 0, data.Length); fs.Flush(); fs.Close(); data = null; ms = null; fs = null; page.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312"); page.Response.HeaderEncoding = System.Text.Encoding.GetEncoding("GB2312"); page.Response.AppendHeader("content-disposition", "attachment;filename=" + System.Web.HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8) + ".xls"); page.Response.ContentType = "Application/excel"; if (page.Response.IsClientConnected) { page.Response.WriteFile(filePath); page.Response.Flush(); } //Response.WriteFile(filePath); //Response.Flush(); try { //删除导出的服务器文件 File.Delete(filePath); } catch (Exception) { } page.Response.Clear(); } private Stream RenderDataTableToExcelSujin(DataTable SourceTable, Page page) { MemoryStream ms = new MemoryStream(); HSSFWorkbook workbook = new NPOI.HSSF.UserModel.HSSFWorkbook(); ISheet sheet = workbook.CreateSheet(); //加标题 IRow headerRow2 = sheet.CreateRow(0); headerRow2.Height = 500; //加了两行空行 IRow dataRow1 = sheet.CreateRow(1); //列高2000 dataRow1.Height = 500; dataRow1.Sheet.SetColumnWidth(0, 50 * 60); dataRow1.Sheet.SetColumnWidth(1, 50 * 60); dataRow1.Sheet.SetColumnWidth(2, 50 * 60); dataRow1.Sheet.SetColumnWidth(3, 50 * 95); IRow dataRow2 = sheet.CreateRow(2); //列高2000 dataRow2.Height = 500; dataRow2.Sheet.SetColumnWidth(0, 50 * 60); dataRow2.Sheet.SetColumnWidth(1, 50 * 60); dataRow2.Sheet.SetColumnWidth(2, 50 * 60); dataRow2.Sheet.SetColumnWidth(3, 50 * 95); //添加Excel的表头 for (int i = 0; i < SourceTable.Columns.Count; i++) { headerRow2.CreateCell(i).SetCellValue(SourceTable.Columns[i].ColumnName); } int rowIndex = 3; Regex regExp = new Regex(@"^(-?\d+)(\.\d+)?$"); List<string> lstColumnname = new List<string>(); foreach (DataColumn item in SourceTable.Columns) { for (int i = 0; i < SourceTable.Rows.Count; i++) { if (SourceTable.Rows[i][item.ColumnName].ToString().Trim().Length > 0) { if (!regExp.IsMatch(SourceTable.Rows[i][item.ColumnName].ToString().Trim())) { lstColumnname.Add(item.ColumnName); break; } } } } foreach (DataRow row in SourceTable.Rows) { IRow dataRow = sheet.CreateRow(rowIndex); //列高2000 dataRow.Height = 500; dataRow.Sheet.SetColumnWidth(0, 50 * 60); dataRow.Sheet.SetColumnWidth(1, 50 * 60); dataRow.Sheet.SetColumnWidth(2, 50 * 60); dataRow.Sheet.SetColumnWidth(3, 50 * 95); ////素金特殊要求:除表头从第三行开始绑定 //if (rowIndex <= 2) //{ // rowIndex++; // continue; //} for (int i = 0; i < SourceTable.Columns.Count; i++) { try { if (row[i].ToString().Trim().Length != 0) { if (lstColumnname.Contains(SourceTable.Columns[i].ColumnName)) dataRow.CreateCell(i).SetCellValue(@row[i].ToString()); else { string aaa = SourceTable.Columns[i].ColumnName; if (row[i].ToString().Contains(".")) { //有小数 转double dataRow.CreateCell(i).SetCellValue(@Convert.ToDouble((row[i].ToString() == "" ? "0" : row[i].ToString()))); } else { //无小数 转int dataRow.CreateCell(i).SetCellValue(@Convert.ToInt32(row[i].ToString())); } } } else dataRow.CreateCell(i).SetCellValue(@row[i].ToString()); } catch (Exception) { dataRow.CreateCell(i).SetCellValue(@row[i].ToString()); } } rowIndex++; } workbook.Write(ms); ms.Flush(); ms.Position = 0; sheet = null; headerRow2 = null; workbook = null; return ms; } ```
求网友 excel导入datagridview时 中出现很多多余的空行 怎么办?
![图片说明](https://img-ask.csdn.net/upload/201609/22/1474542645_122159.png) public void EcxelToDataGridView(string filePath, DataGridView dgv) { //根据路径打开一个Excel文件并将数据填充到DataSet中 string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source = " + filePath + ";Extended Properties ='Excel 8.0;HDR=NO;IMEX=1'";//导入时包含Excel中的第一行数据,并且将数字和字符混合的单元格视为文本进行导入 OleDbConnection conn = new OleDbConnection(strConn); //创建数据源连接对象,并实例化 conn.Open(); //打开数据源连接 string strExcel = ""; //表示从Excel文件获取数据所在栏 OleDbDataAdapter myCommand = null; //表示一个数据连接,用于获取导入文件数据 DataSet ds = null; //开辟一块内存,用于存储导入文件数据 strExcel = "select * from [sheet1$]"; myCommand = new OleDbDataAdapter(strExcel, strConn); ds = new DataSet(); myCommand.Fill(ds, "table1"); //根据DataGridView的列构造一个新的DataTable DataTable tb = new DataTable(); //逐列或许数据表格中DataGridView控件各列 foreach (DataGridViewColumn dgvc in dgv.Columns) { if (dgvc.Visible && dgvc.CellType != typeof(DataGridViewCheckBoxCell)) { DataColumn dc = new DataColumn(); dc.ColumnName = dgvc.DataPropertyName; //dc.DataType = dgvc.ValueType;//若需要限制导入时的数据类型则取消注释,前提是DataGridView必须先绑定一个数据源那怕是空的DataTable tb.Columns.Add(dc); } } //根据Excel的行逐一对上面构造的DataTable的列进行赋值 foreach (DataRow excelRow in ds.Tables[0].Rows) { int i = 0; DataRow dr = tb.NewRow(); foreach (DataColumn dc in tb.Columns) { dr[dc] = excelRow[i]; i++; } tb.Rows.Add(dr); } //在DataGridView中显示导入的数据 //dgv.Columns.Clear(); //dgv. = tb; for (int curRow = 1; curRow < tb.Rows.Count; curRow++) { dgv.Rows.Add(1); for (int curCol = 0; curCol < tb.Columns.Count; curCol++) { dgv.Rows[curRow - 1].Cells[curCol].Value = tb.Rows[curRow][curCol].ToString(); } } } private void button2_Click(object sender, EventArgs e) { //打开一个文件选择框 OpenFileDialog ofd = new OpenFileDialog(); //为了获取特定的系统文件夹,可以使用System.Environment类的静态方法GetFolderPath()。该方法接受一个Environment.SpecialFolder枚举,其中可以定义要返回路径的哪个系统目录 ofd.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments); ofd.Filter = "Excel文件(*.xls)|*.xls"; //使导入文件格式为03版Excel文件 //文件有效性验证ValidateNames,验证用户输入是否是一个有效的Windows文件名 ofd.ValidateNames = true; ofd.CheckFileExists = true; //验证路径有效性 string strName = string.Empty; //用来储存导入文件的文件名 if (ofd.ShowDialog() == DialogResult.OK) //判断是否存在导入文件 { strName = ofd.FileName; } if (strName == "") { //如果没有选择导入文件,进行提示,退出当前操作。 MessageBox.Show("没有选择Excel文件!无法进行数据导入"); return; } //调用导入数据方法 EcxelToDataGridView(strName, dataGridView1); }
怎样快速提升excel导入数据库的速度
protected void Button1_Click(object sender, EventArgs e) { string fianlfilename = upload(); show(fianlfilename); string strSQL = ""; DataTable dt=show(fianlfilename); for (int i = 0; i <dt.Rows.Count; i++) { strSQL +="insert into test1 values('" + dt.Rows[i][0].ToString () + "','" + dt.Rows[i][1].ToString() + "','" + dt.Rows[i][2].ToString() + "')"; } INSERT(strSQL); } private string upload() { HttpPostedFile file = FileUpload1.PostedFile; string filename = file.FileName;//文件名+文件路径 filename = System.IO.Path.GetFileName(filename);//提取filename中的文件名(不带路径) string serverfilepath=Server.MapPath(".")+"//wenjian//";//获得服务器保存的文件夹路径 string fianlfilename=serverfilepath+filename; file.SaveAs(fianlfilename); return fianlfilename; } private DataTable show(string strpath) { string strConn = "provider=Microsoft.JET.OLEDB.4.0;Data Source='"+strpath+"';Extended Properties='Excel 8.0;HDR=YES;IMEX=1';"; //string strConn = "Provider=Microsolf.JET.OLEDB.4.0;Data Source='D:\\123.xlsx';Extended Properties=Excel 8.0;"; //string strConn = "Provider=Microsolf.ACE.OLEDB.12.0;Data Source='D:\\Book1.xls';Extended Properties='Excel 8.0;HDR=YES;IMEX=1';"; OleDbConnection conn = new OleDbConnection(strConn); conn.Open(); string strSQL = "select * from[Sheet1$]"; OleDbDataAdapter da = new OleDbDataAdapter(strSQL, conn); DataTable dt = new DataTable(); da.Fill(dt); conn.Close(); GridView1.DataSource = dt; GridView1.DataBind(); return dt; } private void INSERT(string strSQL) { string strConn = "data source=DESKTOP-JAUDH78\\QWERT;initial catalog=KAOQINXITONG;uid=sa;password=123456;"; SqlConnection conn = new SqlConnection(strConn); conn.Open(); SqlCommand cmd = new SqlCommand(strSQL,conn); cmd.ExecuteNonQuery(); conn.Close(); } }
为什么实现不了上传和下载功能啊,求大神指导
<asp:FileUpload ID="file" runat="server" /> </td> <td> <telerik:RadButton ID="but_import" runat="server" Text="上传" OnClick="but_import_Click"></telerik:RadButton> </td> </tr> </table> </fieldset> </div> <div> <telerik:RadGrid runat="server" ID="grid_view" AutoGenerateColumns="false" AllowPaging="true" PageSize="15" AllowCustomPaging="true" OnNeedDataSource="grid_view_NeedDataSource" OnItemCommand="grid_ItemCommand"> <MasterTableView DataKeyNames="filename"> <Columns> <telerik:GridBoundColumn HeaderText="上传人" DataField="oper_name"></telerik:GridBoundColumn> <telerik:GridBoundColumn HeaderText="上传时间" DataField="time"></telerik:GridBoundColumn> <telerik:GridBoundColumn HeaderText="上传文件名" DataField="filename"></telerik:GridBoundColumn> <telerik:GridButtonColumn ButtonType="PushButton" HeaderText="下 载" ConfirmDialogType="RadWindow" ConfirmText="确定下载吗!?" CommandName="del" Text="下 载" ConfirmTitle="提示信息" ConfirmDialogHeight="80" > </telerik:GridButtonColumn> </Columns> protected void but_import_Click(object sender, EventArgs e) { //上传,添加 try { DataTable table = this.ImportFile(); if (table != null && table.Rows.Count > 0) { DataTable tble = this.NewTable(table); if (tble != null && tble.Rows.Count != 0) { Save(tble); } } else { Pub.Util.AlertPostBack(this.Page, "请导入Excel文件或Word文件!"); } } catch { Pub.Util.AlertPostBack(this.Page, "导入失败!"); } } private DataTable NewTable(DataTable data) { DataTable table = new DataTable(); return table; } private void Save(DataTable table) { Pub.Util.AlertPostBack(this.Page, "导入成功"); } private DataTable ImportFile() { DataTable table = null; if (this.IsFile()) { string temDir = Common.AppSetting.Upload_Temp_Path(); this.file.PostedFile.SaveAs(temDir + this.file.FileName); table = AsposeHelper.ExcelToDataTable(temDir + this.file.FileName, true); System.IO.File.Delete(temDir + this.file.FileName); } return table; } private bool IsFile() { bool isFiel = false; if (this.file.HasFile) { string fileName = this.file.FileName.ToLower(); if (fileName.EndsWith("xlsx") || fileName.EndsWith("xls") || fileName.EndsWith("doc") || fileName.EndsWith("docx")) { isFiel = true; } } return isFiel; } protected void grid_view_NeedDataSource(object sender, Telerik.Web.UI.GridNeedDataSourceEventArgs e) { DAL_ODP.DefineSql defineSql = new DAL_ODP.DefineSql(); defineSql.AddSql("select a.oper_name,b.time,b.filename from sl_sys.t_sys_oper@dbmaizhi a inner join suxj.t_74_upload@do10 b on a.id = b.create_oper_id where a.id=" + LoginUser.ID); int total, pagetotal; grid_view.DataSource = defineSql.Query_Do10_Page(grid_view.CurrentPageIndex, grid_view.PageSize, out total, out pagetotal); grid_view.VirtualItemCount = total; } protected void grid_ItemCommand(object sender, Telerik.Web.UI.GridCommandEventArgs e) { string s = e.CommandName; if (s == "del") { //添加记录 string file_load = grid_view.MasterTableView.DataKeyValues[e.Item.ItemIndex]["filename"].ToString(); DAL_ODP.DefineSql defineSql = new DAL_ODP.DefineSql(); defineSql.AddSql("insert into suxj.t_74_load(filename) values({0})" ,file_load); defineSql.ExecuteSql_Do10(); grid_view.Rebind(); } } }
Kafka实战(三) - Kafka的自我修养与定位
Apache Kafka是消息引擎系统,也是一个分布式流处理平台(Distributed Streaming Platform) Kafka是LinkedIn公司内部孵化的项目。LinkedIn最开始有强烈的数据强实时处理方面的需求,其内部的诸多子系统要执行多种类型的数据处理与分析,主要包括业务系统和应用程序性能监控,以及用户行为数据处理等。 遇到的主要问题: 数据正确性不足 数据的收集主要...
volatile 与 synchronize 详解
Java支持多个线程同时访问一个对象或者对象的成员变量,由于每个线程可以拥有这个变量的拷贝(虽然对象以及成员变量分配的内存是在共享内存中的,但是每个执行的线程还是可以拥有一份拷贝,这样做的目的是加速程序的执行,这是现代多核处理器的一个显著特性),所以程序在执行过程中,一个线程看到的变量并不一定是最新的。 volatile 关键字volatile可以用来修饰字段(成员变量),就是告知程序任何对该变量...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
有哪些让程序员受益终生的建议
从业五年多,辗转两个大厂,出过书,创过业,从技术小白成长为基层管理,联合几个业内大牛回答下这个问题,希望能帮到大家,记得帮我点赞哦。 敲黑板!!!读了这篇文章,你将知道如何才能进大厂,如何实现财务自由,如何在工作中游刃有余,这篇文章很长,但绝对是精品,记得帮我点赞哦!!!! 一腔肺腑之言,能看进去多少,就看你自己了!!! 目录: 在校生篇: 为什么要尽量进大厂? 如何选择语言及方...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
GitHub开源史上最大规模中文知识图谱
近日,一直致力于知识图谱研究的 OwnThink 平台在 Github 上开源了史上最大规模 1.4 亿中文知识图谱,其中数据是以(实体、属性、值),(实体、关系、实体)混合的形式组织,数据格式采用 csv 格式。 到目前为止,OwnThink 项目开放了对话机器人、知识图谱、语义理解、自然语言处理工具。知识图谱融合了两千五百多万的实体,拥有亿级别的实体属性关系,机器人采用了基于知识图谱的语义感...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
微信支付崩溃了,但是更让马化腾和张小龙崩溃的竟然是……
loonggg读完需要3分钟速读仅需1分钟事件还得还原到昨天晚上,10 月 29 日晚上 20:09-21:14 之间,微信支付发生故障,全国微信支付交易无法正常进行。然...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
英特尔不为人知的 B 面
从 PC 时代至今,众人只知在 CPU、GPU、XPU、制程、工艺等战场中,英特尔在与同行硬件芯片制造商们的竞争中杀出重围,且在不断的成长进化中,成为全球知名的半导体公司。殊不知,在「刚硬」的背后,英特尔「柔性」的软件早已经做到了全方位的支持与支撑,并持续发挥独特的生态价值,推动产业合作共赢。 而对于这一不知人知的 B 面,很多人将其称之为英特尔隐形的翅膀,虽低调,但是影响力却不容小觑。 那么,在...
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
白话阿里巴巴Java开发手册高级篇
不久前,阿里巴巴发布了《阿里巴巴Java开发手册》,总结了阿里巴巴内部实际项目开发过程中开发人员应该遵守的研发流程规范,这些流程规范在一定程度上能够保证最终的项目交付质量,通过在时间中总结模式,并推广给广大开发人员,来避免研发人员在实践中容易犯的错误,确保最终在大规模协作的项目中达成既定目标。 无独有偶,笔者去年在公司里负责升级和制定研发流程、设计模板、设计标准、代码标准等规范,并在实际工作中进行...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
YouTube排名第一的励志英文演讲《Dream(梦想)》
Idon’t know what that dream is that you have, I don't care how disappointing it might have been as you've been working toward that dream,but that dream that you’re holding in your mind, that it’s po...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
Java世界最常用的工具类库
Apache Commons Apache Commons有很多子项目 Google Guava 参考博客
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
【技巧总结】位运算装逼指南
位算法的效率有多快我就不说,不信你可以去用 10 亿个数据模拟一下,今天给大家讲一讲位运算的一些经典例子。不过,最重要的不是看懂了这些例子就好,而是要在以后多去运用位运算这些技巧,当然,采用位运算,也是可以装逼的,不信,你往下看。我会从最简单的讲起,一道比一道难度递增,不过居然是讲技巧,那么也不会太难,相信你分分钟看懂。 判断奇偶数 判断一个数是基于还是偶数,相信很多人都做过,一般的做法的代码如下...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车?某胡同口的煎饼摊一年能卖出多少个煎饼?深圳有多少个产品经理?一辆公交车里能装下多少个乒乓球?一个正常成年人有多少根头发?这类估算问题,被称为费米问题,是以科学家费米命名的。为什么面试会问这种问题呢?这类问题能把两类人清楚地区分出来。一类是具有文科思维的人,擅长赞叹和模糊想象,它主要依靠的是人的第一反应和直觉,比如小孩...
相关热词 c# clr dll c# 如何orm c# 固定大小的字符数组 c#框架设计 c# 删除数据库 c# 中文文字 图片转 c# 成员属性 接口 c#如何将程序封装 16进制负数转换 c# c#练手项目
立即提问