c#获取excel文件里的内容有几行

打开现有的excel文档,如何获知里面的内容到第几行了我需要接着现有的内容逐行往下写东西... 打开现有的excel文档,如何获知里面的内容到第几行了
我需要接着现有的内容逐行往下写东西
展开
 我来答
斯内科Snake
2014-03-04 · TA获得超过523个赞
知道小有建树答主
回答量:707
采纳率:50%
帮助的人:248万
展开全部
/// <summary>
        /// 将 Excel 文件转成 DataTable
        /// </summary>
        /// <param name="serverMapPathExcel">Excel文件及其路径</param>
        /// <param name="strSheetName">工作表名,如:Sheet1$</param>
        /// <param name="isTitleOrDataOfFirstRow">True 第一行是标题,False 第一行是数据</param>
        /// <returns>DataTable</returns>
        public DataTable ExcelToDataTable(string serverMapPathExcel, string strSheetName, bool isTitleOrDataOfFirstRow, int index)
        {
            string HDR = string.Empty;//如果第一行是数据而不是标题的话, 应该写: "HDR=No;"
            if (isTitleOrDataOfFirstRow)
            {
                HDR = "YES";//第一行是标题
            }
            else
            {
                HDR = "NO";//第一行是数据
            }
            //源的定义 
            string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + serverMapPathExcel + ";" + "Extended Properties='Excel 8.0;HDR=" + HDR + ";IMEX=1';";
            //Sql语句
            //string strExcel = string.Format("select * from [{0}$]", strSheetName); 这是一种方法
            //string strExcel = "select * from [" + strSheetName + "]";
            ////定义存放的数据表
            //DataSet ds = new DataSet();
            DataTable dt = new DataTable();
            //连接数据源
            using (OleDbConnection conn = new OleDbConnection(strConn))
            {
                try
                {
                    conn.Open();
                    DataTable dtSchema = conn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables, null);
                    conn.Close();
 
                    //MessageBox.Show(dtSchema.Rows.Count.ToString() + "列:" + dtSchema.Columns.Count);
                    //for (int i = 0; i < dtSchema.Rows.Count; i++)
                    //{
                    //    richTextBox1.Text = richTextBox1.Text + (i + ":" + dtSchema.Rows[i][2].ToString()) + "\n";
                    //}
                    string tableName = dtSchema.Rows[index][2].ToString().Trim();
                    MessageBox.Show(tableName);
                    OleDbCommand OleDbCommand = new OleDbCommand("SELECT * FROM [" + tableName + "A1:AK2000]", conn);//excel的AG列
                    //OleDbCommand OleDbCommand = new OleDbCommand("SELECT * FROM [" + tableName + "]", conn);
                    OleDbDataAdapter oa = new OleDbDataAdapter(OleDbCommand);
                    oa.FillSchema(dt, SchemaType.Source);
                    oa.Fill(dt);
                    //oa.FillSchema(dt2, SchemaType.Source);
                    //oa.Fill(dt2);
                    //RemoveEndEmptyLines(ref dt2, dt2.Rows.Count - 1);
                    //dt2.Rows.RemoveAt(0);
 
                    //dataGridView1.DataSource = dt2;
 
                    //适配到数据源
                    //OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, strConn);
                    //adapter.Fill(ds, strSheetName);
                }
                catch (Exception ex)
                {
                    MessageBox.Show(ex.Message, "Error");
                }
                finally
                {
                    conn.Close();
                    conn.Dispose();
                }
            }
            return dt;//ds.Tables[strSheetName];
        } 
        //调用时
        OpenFileDialog ofd = new OpenFileDialog();
            ofd.Multiselect = false;
            ofd.Title = "请选择入职员工所在的Excel文件[请确保该Excel已关闭]";
            ofd.Filter = "excel file|*.xls|所有文件|*.*";
            if (ofd.ShowDialog() == DialogResult.OK)
            {
                int hireIndex = int.Parse(numericUpDown1.Value.ToString("N0"));//入职表格所在的 所在的索引
                //richTextBox1.Text = richTextBox1.Text + hireIndex + "\n";
                try
                {
                    DataTable dt = ExcelToDataTable(ofd.FileName, "Sheet1$", true, hireIndex);
                    richTextBox1.Text = richTextBox1.Text + "行数:" + dt.Rows.Count + "\n";
                    Application.DoEvents();
                    }
                catch (Exception ex) 
                {
                    MessageBox.Show(ex.Message, "Error,请检查excel是否符合规则");
                    richTextBox1.Text = richTextBox1.Text + "导入出错";
                    Application.DoEvents();
                    return;
                }
                richTextBox1.Text = richTextBox1.Text + "操作结束";
                Application.DoEvents();
            }
//返回的DataTable 的行数 就是你要的结果
更多追问追答
追问
那除了这种方式 ,还有没有其他方式,谢谢
追答
你如果是打开一个Excel,然后在Excel的行中写东西,那么C#项目中添加操作Excel的类库
一般是Microsoft.Interop.Office.Excel 操作这个类库下面的类
小飞侠2014
2014-03-04 · TA获得超过280个赞
知道小有建树答主
回答量:137
采纳率:0%
帮助的人:74.1万
展开全部
将excel数据读取到dataset中,取到Tables(0).Rows.Count 即可。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2014-03-04
展开全部
问题没表述清楚
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
哈尼霍霍
2017-12-06
知道答主
回答量:1
采纳率:0%
帮助的人:932
展开全部
int row_ = xlsheet.UsedRange.Rows.Count;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式