dataGridView1.Rows[0].Cells[0].Value.ToString(),放在代码不同位置值为什么会不一样

Mr.Yun 2014-10-23 12:26:59
//dataGridView1初始化
private void init()
{
String sql = "select NO 补料单号 ,GYSMC 供应商 ,RQ 下单日期 from BFD_GC_GYS WHERE QDXL=0";

MyTable = DataConnection.Datagridview_(sql);
this.dataGridView1.DataSource = MyTable;
DataGridViewButtonColumn column_ = new DataGridViewButtonColumn();// 添加一个复选框
// column_.AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;//调整列宽
column_.UseColumnTextForButtonValue = true;
column_.HeaderText = "已下料给客户";
column_.Text = "确定";//设置文字
dataGridView1.Columns.Insert(dataGridView1.Columns.Count, column_); //指导位置添加一列

DataGridViewButtonColumn column_1 = new DataGridViewButtonColumn();// 按钮
column_1.UseColumnTextForButtonValue = true;
column_1.Text = "查看";//设置文字
column_1.HeaderText = "查看详细";
this.dataGridView1.Columns.Insert(dataGridView1.Columns.Count, column_1);

DataGridViewButtonColumn column_2 = new DataGridViewButtonColumn();// 按钮
column_2.UseColumnTextForButtonValue = true;
column_2.Text = "打印下料单";//设置文字
column_2.HeaderText = "打印下料单";
this.dataGridView1.Columns.Insert(dataGridView1.Columns.Count, column_2);

DataGridViewButtonColumn column_3 = new DataGridViewButtonColumn();// 按钮
column_3.UseColumnTextForButtonValue = true;
column_3.Text = "修改";//设置文字
column_3.HeaderText = "修改";
this.dataGridView1.Columns.Insert(dataGridView1.Columns.Count, column_3);

DataGridViewButtonColumn column_4 = new DataGridViewButtonColumn();// 按钮
column_4.UseColumnTextForButtonValue = true;
column_4.Text = "删除";//设置文字
column_4.HeaderText = "删除";
this.dataGridView1.Columns.Insert(dataGridView1.Columns.Count, column_4);


MessageBox.Show("初始化 "+dataGridView1.Rows[0].Cells[0].Value.ToString());
}

private void HS_BLDCX_Load(object sender, EventArgs e)
{
init();
}

private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
DataGridViewColumn column = dataGridView1.Columns[e.ColumnIndex];
if (column is DataGridViewButtonColumn && column.HeaderText == "修改")
{
MessageBox.Show("点击修改按钮 "+dataGridView1.Rows[0].Cells[0].Value.ToString());
/* HS_BLDXG.NO = dataGridView1.Rows[dataGridView1.CurrentRow.Index].Cells[5].Value.ToString();
HS_BLDXG bldxg = new HS_BLDXG();
Main_Form.Panel_change(bldxg);*/
}
...省略其他情况
}

...全文
1285 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
D56233577 2014-10-23
  • 打赏
  • 举报
回复
你插入列,改变了索引,所以你不应该用索引,应该用名字。 你可以断点进去看看是不是我说的,如果是就散分吧。
忘丿殇 2014-10-23
  • 打赏
  • 举报
回复
没看懂的说。。。什么叫代码放在不同的地方?
Mr.Yun 2014-10-23
  • 打赏
  • 举报
回复
我要它显示[0,0]位置的值,但是显示代码放在不同地方值居然是不一样的!有哪位大神知道其中的原有吗
Mr.Yun 2014-10-23
  • 打赏
  • 举报
回复
引用 8 楼 superior_yong 的回复:
        private void gridCust_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            try
            {
                int CIndex = e.ColumnIndex;
                int RIndex = e.RowIndex;
                if (CIndex == 6)
                {
                         MessageBox.Show("点击修改按钮         "+gridCust.Rows[RIndex].Cells["补料单号"].Value.ToString() );                 
                }
            }

        }
其实这样写也可以
其实更直白的是gridCust.Rows[e.RowIndex].Cells["补料单号"].Value.ToString() ;就好! 我现在就想知道为什么在有的窗体里面会索引会变,有的却不会
忘丿殇 2014-10-23
  • 打赏
  • 举报
回复
        private void gridCust_CellClick(object sender, DataGridViewCellEventArgs e)
        {
            try
            {
                int CIndex = e.ColumnIndex;
                int RIndex = e.RowIndex;
                if (CIndex == 6)
                {
                         MessageBox.Show("点击修改按钮         "+gridCust.Rows[RIndex].Cells["补料单号"].Value.ToString() );                 
                }
            }

        }
其实这样写也可以
Mr.Yun 2014-10-23
  • 打赏
  • 举报
回复
引用 3 楼 D56233577 的回复:
你插入列,改变了索引,所以你不应该用索引,应该用名字。 你可以断点进去看看是不是我说的,如果是就散分吧。
正如你所说的,但是为什么在别的程序就不会出现,这种情况也是部分有部分没有! 其他窗体程序也是 有插入列
exception92 2014-10-23
  • 打赏
  • 举报
回复
不知 所云。。。
Mr.Yun 2014-10-23
  • 打赏
  • 举报
回复
引用 4 楼 Z65443344 的回复:
把this.dataGridView1.Columns.Insert改成this.dataGridView1.Columns.Add再试
想问下它们区别是什么?
於黾 2014-10-23
  • 打赏
  • 举报
回复
把this.dataGridView1.Columns.Insert改成this.dataGridView1.Columns.Add再试
dbfC#DataGridView中的常用技巧 只列出技巧部分,后面有补充 0(最基本的技巧). 获取某列中的某行(某单元格)中的内容 this.currentposition = this.dataGridView1.BindingContext [this.dataGridView1.DataSource, this.dataGridView1.DataMember].Position; bookContent = this.database.dataSet.Tables[0].Rows [this.currentposition][21].ToString().Trim(); MessageBox.Show(bookContent); 1、自定义列 //定义列宽 this.dataGridView1.Columns[0].Width = 80; this.dataGridView1.Columns[1].Width = 80; this.dataGridView1.Columns[2].Width = 180; this.dataGridView1.Columns[3].Width = 120; this.dataGridView1.Columns[4].Width = 120; Customize Cells and Columns in the Windows Forms DataGridView Control by Extending Their Behavior and Appearance Host Controls in Windows Forms DataGridView Cells 继承 DataGridViewTextBoxCell 类生成新的Cell类,然后再继承 DataGridViewColumn 生成新的Column类,并指定 CellTemplate为新的Cell类。新生成的Column便可以增加到DataGridView中去。 2、自动适应列宽 Programmatically Resize Cells to Fit Content in the Windows Forms DataGridView Control Samples: DataGridView.AutoSizeColumns( DataGridViewAutoSizeColumnCriteria.HeaderAndDisplayedRows); DataGridView.AutoSizeColumn( DataGridViewAutoSizeColumnCriteria.HeaderOnly, 2, false); DataGridView.AutoSizeRow( DataGridViewAutoSizeRowCriteria.Columns, 2, false); DataGridView.AutoSizeRows( DataGridViewAutoSizeRowCriteria.HeaderAndColumns, 0, dataGridView1.Rows.Count, false); 3、可以绑定并显示对象 Bind Objects to Windows Forms DataGridView Controls 4、可以改变表格线条风格 Change the Border and Gridline Styles in the Windows Forms DataGridView Control Samples: this.dataGridView1.GridColor = Color.BlueViolet; this.dataGridView1.BorderStyle = BorderStyle.Fixed3D; this.dataGridView1.CellBorderStyle = DataGridViewCellBorderStyle.None; this.dataGridView1.RowHeadersBorderStyle = DataGridVie
public void print(DataGridView dataGridView1) { //导出到execl try { //没有数据的话就不往下执行 if (dataGridView1.Rows.Count == 0) return; //实例化一个Excel.Application对象 Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application(); //让后台执行设置为不可见,为true的话看到打开一个Excel,然后数据在往里写 excel.Visible = false; //新增加一个工作簿,Workbook是直接保存,不弹出保存对话框,加上Application弹出保存对话框,为false报错 excel.Application.Workbooks.Add(true); //生成Excel中列头名称 for (int i = 0; i < dataGridView1.Columns.Count; i++) { excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText; } //把DataGridView当前页的数据保存在Excel中 for (int i = 0; i < dataGridView1.Rows.Count - 1; i++) { for (int j = 0; j < dataGridView1.Columns.Count; j++) { if (dataGridView1[j, i].ValueType == typeof(string)) { excel.Cells[i + 2, j + 1] = "'" + dataGridView1[j, i].Value.ToString(); } else { excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString(); } } } //设置禁止弹出保存和覆盖的询问提示框 excel.DisplayAlerts = false; excel.AlertBeforeOverwriting = false; //保存工作簿 excel.Application.Workbooks.Add(true).Save(); //保存excel文件 excel.Save("C:" + "\\KKHMD.xls"); //确保Excel进程关闭 excel.Quit(); excel = null; } catch (Exception ex) { MessageBox.Show(ex.Message, "错误提示"); } }

110,535

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

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