请问如何从Excel的第三行开始插入数据

net5354 2011-03-13 11:57:27
我的Excel模板是这样的
第一行是合并单元格,用来显示标题
第二行每个单元格显示字段,如下所示


我用常规方法测试不成功
string filePath = Server.MapPath("~/" + "demo1.xls");
OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties='Excel 8.0;HDR=No;IMEX=0'");
using (conn)
{
conn.Open();
OleDbCommand cmd = new OleDbCommand("INSERT INTO [Sheet1$](F1)VALUES(@b)", conn);
cmd.Parameters.AddWithValue("@b", "100");
conn.Close();
conn.Open();
cmd.ExecuteNonQuery();
conn.Close();
}
提示:“INSERT INTO 语句包含下列未知的字段名: 'F1'。确定键入的名称是正确的, 然后重试。”
如果把第一行合并单元格去掉是可以插入数据的,但我想保留这个模板格式。

请问怎样在第三行才开始插入数据?
INSERT INTO [Sheet1$](F1)VALUES(@b) WHERE 行号>=3
行号>=3”怎么表达?
十分感谢!
...全文
1381 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
haixinl2012 2013-08-29
  • 打赏
  • 举报
回复
求解啊,遇到同样的问题了
net5354 2011-03-16
  • 打赏
  • 举报
回复
哎...真是难搞,在这里问了几个问题得到解决的不到50%
本人笨啊!
真是没办法了吗?
net5354 2011-03-16
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 chinaway1984 的回复:]
试试 INSERT INTO ([班别],[姓名],……) values('值','值',)
[/Quote]不能的,因为第一行是合并单元格,不是字段名
chinaway_csdn 2011-03-16
  • 打赏
  • 举报
回复
试试 INSERT INTO ([班别],[姓名],……) values('值','值',)
net5354 2011-03-16
  • 打赏
  • 举报
回复
还是不能解决
子夜__ 2011-03-14
  • 打赏
  • 举报
回复
子夜__ 2011-03-14
  • 打赏
  • 举报
回复
指定行插入数据

myWorkBooks = myExcel.Workbooks;
myWorkBook = myWorkBooks.Add(System.Reflection.Missing.Value);
myWorkSheet = (Excel.Worksheet)myWorkBook.Worksheets[1];
myColumns = (char)(this.dgvUserInfo.Columns.Count + 64);//设置列
myRange = myWorkSheet.get_Range("A4", myColumns.ToString() + "5");//设置列宽
int count = 1;//第一列为空
//设置列名
foreach (DataColumn myNewColumn in tempTable.Columns)
{
myData[0, count] = myNewColumn.ColumnName;
count = count + 1;
}
//输出datagridview中的数据记录并放在一个二维数组中
j = 1;
foreach (DataRow myRow in tempTable.Rows)//循环行
{
for (i = 1; i <= tempTable.Columns.Count; i++)//循环列
{
myData[j, i] = myRow[i - 1].ToString();
}
j++;
}
//将二维数组中的数据写到Excel中
myRange = myRange.get_Resize(tempTable.Rows.Count + 1, tempTable.Columns.Count);//创建列和行
myRange.Value2 = myData;
myRange.EntireColumn.AutoFit();
myWorkSheet.Cells[2, 2] = "符合您选择条件的数据信息";\\这里写成这样就行了myWorkSheet.Cells[你要指定的行, 你要指定的列]
Excel.Range myRange22 = myWorkSheet.get_Range("B2", "B2");
myRange22.Font.Bold = true;
myRange22.Font.Size = "20";
myWorkSheet.Cells[3, 1] = "导出日期:" + DateTime.Now.ToString();
net5354 2011-03-14
  • 打赏
  • 举报
回复
多谢!
但你提供的两个方法我都不会用,我只要求最简单的:
INSERT INTO [Sheet1$](F1)VALUES(@b) WHERE 行号?>=3

这个Excel的“行号”如何表达
net5354 2011-03-14
  • 打赏
  • 举报
回复
我是在asp.net中用,但还是不会,
请帮助

62,243

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧