winform中DatagridView单元格赋值问题

leiaming 2008-11-24 06:05:47
数据库的字段是int型(值是0和1),绑定后单元格需要显示字符串(disable和Enable),但gridview1.Rows[i].Cells["Status"].Value就是不给赋非数字型字符串,"12345"没问题,"Enable"就报错,请问如何重新设置单元格类型,谢谢
...全文
933 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
tinghai_xu 2008-11-25
  • 打赏
  • 举报
回复
将你的数据源先转换为你的Grid显示需要的格式,保存的时候先从Grid显示的格式转换成存储需要的格式,然后再存储,
比如:你从数据库查出的是UserID,Name,Sex(其中Sex为bit)的DataTable(OriginalView)但是你需要显示为Male,Female,那么你可以新建一个DataTable(DisplayView),使用一个方法将OriginalView的数据转换到DisplayView种,然后使用DisplayView来绑定Grid,保存的时候先转换成OriginalView然后再存到数据库。这是通用的方法,不一定方便,但是可以适应大多数的情况,仅供参考哈。
gomoku 2008-11-25
  • 打赏
  • 举报
回复
...那要编辑字段怎么办...
this.gridview1.CellParsing += OnCellParsing ;
void OnCellParsing( ... )
{
if( e.ColumnIndex == dataGridView1.Columns["Status"].Index )
{
if( (e.Value as string) == "Enable" )
{
e.Value = 1;
}
else
{
e.Value = 0;
}
e.ParsingApplied = true;
}
}
冷月孤峰 2008-11-25
  • 打赏
  • 举报
回复
在SQL语句中就直接设定好了就行了,在SQL语句中用case语句:
CASE Status
WHEN '1' THEN 'disable'
WHEN '2' THEN 'Enable'
ELSE '其他' END
leiaming 2008-11-25
  • 打赏
  • 举报
回复
难道绑定数据后,就不能改变类型吗?那要编辑字段怎么办,好像绑定前也不能设置类型啊,Datagridview的字段类型是随数据库字段而定的,我们不能改变吗?
bloodish 2008-11-24
  • 打赏
  • 举报
回复
CellFormating事件可以格式化字符串,
再举个例子,如果这个Cell中你放的是一个DateTime的数据,
你可以设置Format来格式化你想要的时间显示方式
bloodish 2008-11-24
  • 打赏
  • 举报
回复

this.gridview1.CellFormatting += OnCellFormatting;
private void OnCellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
{
if (e.ColumnIndex == dataGridView1.Columns["Status"].Index)
{
int val = (int)gridview1.Rows[e.RowIndex].Cells["Status"].Value;
if(val == 0)
{
e.CellStyle.Format = "Disable";
}
else
{
e.CellStyle.Format = "Enable";
}
}
wangping_li 2008-11-24
  • 打赏
  • 举报
回复
我不知道你为什么要赋Enable值
如果你一定要这样的话就不要把单元格和
Status字段绑定
gridview1.Rows[i].Cells[列索引].Value="你想填充的值";
wangping_li 2008-11-24
  • 打赏
  • 举报
回复
gridview1.Rows[i].Cells["Status"].Value
你这一句绑定的时候就已经把这个类型给定了,你还怎么设置?
wangping_li 2008-11-24
  • 打赏
  • 举报
回复
首先看你Status是什么类型的,如果是你int型的话,赋与Enable肯定是不可以的
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

111,093

社区成员

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

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

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