//显示行号
private void dataGridView1_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e)
{
System.Drawing.Rectangle rectangle = new System.Drawing.Rectangle(e.RowBounds.Location.X,
e.RowBounds.Location.Y,
dataGridView1.RowHeadersWidth - 4,
e.RowBounds.Height);
TextRenderer.DrawText(e.Graphics, (e.RowIndex + 1).ToString(),
dataGridView1.RowHeadersDefaultCellStyle.Font,
rectangle,
dataGridView1.RowHeadersDefaultCellStyle.ForeColor,
TextFormatFlags.VerticalCenter | TextFormatFlags.Right);
}
//在页面上拖放一个DataGridView控件
//连接数据库读取数据,为DataGridView赋值。
String strConn = "server= .XWPC_DATABASE;uid=数据库用户名;pwd=数据库密码;database=数据库名";
SqlConnection conn = new SqlConnection(strConn);
String sqlId = "select * from [USER] ";
conn.Open();
SqlCommand cmd = new SqlCommand(sqlId, conn);
SqlDataAdapter da = new SqlDataAdapter(cmd);
DataSet ds = new DataSet();
da.Fill(ds, "USER");
DataGridView.DataSource = ds;
DataGridView.DataMember = "USER";
conn.Close();
//建立一个DataTable
private DataTable InitDt()
{
DataTable dt = new DataTable("个人简历");
dt.Columns.Add("id", typeof(int));
dt.Columns.Add("name", typeof(string));
dt.Columns.Add("sex", typeof(int));
dt.Columns.Add("address", typeof(string));
dt.Columns.Add("aihao", typeof(string));
dt.Columns.Add("photo", typeof(string));
dt.Rows.Add(new object[] { 1, "张三", 1, "东大街6号", "看书", "" });
dt.Rows.Add(new object[] { 1, "王五", 0, "西大街2号", "上网,游戏", "" });
dt.Rows.Add(new object[] { 1, "李四", 1, "南大街3号", "上网,逛街", "" });
dt.Rows.Add(new object[] { 1, "钱八", 0, "北大街5号", "上网,逛街,看书,游戏", "" });
dt.Rows.Add(new object[] { 1, "赵九", 1, "中大街1号", "看书,逛街,游戏", "" });
return dt;
}
//循环kDataGridView1
for (int i = 0; i < this.kDataGridView1.Rows.Count;i++ )
{
switch (this.kDataGridView1[4, i].Value.ToString()) //第一个数为列,第二个为行
{
case "0":
this.kDataGridView1[4,i].Value = "未用";
break;
case "1":
this.kDataGridView1[4,i].Value = "正常";
break;
case "2":
this.kDataGridView1[4,i].Value = "停用";
break;
case "3":
this.kDataGridView1[4,i].Value = "废弃";
break;
default:
this.kDataGridView1[4,i].Value = "其他";
break;
}
}
//判断kDataGridView1第i行第5列额值
if (kDataGridView1.Rows[i].Cells[5].Value.ToString().Trim() != "")
{
MessageBox.Show("所选行中有分发过的卡,请重新选择!");
return;
}
//循环kDataGridView1,判断行是否有被选中
for(int i=0;i < this.kDataGridView1.Rows.Count;i++ )
{
DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)kDataGridView1.Rows[i].Cells[0];
Boolean flag = Convert.ToBoolean(checkCell.Value);
if (flag == true) //查找被选择的数据行
{
}
}
//点击第一列则选中所有行(或者是反选)
if (kDataGridView1.CurrentCell.ColumnIndex == 1)
{
int count = kDataGridView1.Rows.Count;
for (int i = 0; i < count; i++)
{
DataGridViewCheckBoxCell checkCell = (DataGridViewCheckBoxCell)kDataGridView1.Rows[i].Cells[0];
Boolean flag = Convert.ToBoolean(checkCell.Value);
if (flag == false) //查找被选择的数据行
{
checkCell.Value = true;
}
else
checkCell.Value = false;
}
}
//dataGridView定位
string id = this.k_id.Text.ToString().Trim();
if (id.Length != 0)
{
for (int i = 0; i < this.kDataGridView1.Rows.Count; i++)
{
if(this.kDataGridView1[0, i].Value.ToString().Trim()==id)
{
this.kDataGridView1.CurrentCell = kDataGridView1.Rows[i].Cells[0];
return;
}
}
}
//遍历dataTable
if (dt != null && dt.Rows.Count > 0)
{
foreach (DataRow row in dt.Rows) //遍历行
{
for (int i = 0; i < dt.Columns.Count; i++)
{
sql1 = sql1 + dt.Columns[i].ColumnName + "= '" + row[i].ToString() + "',";
// user_id = "123",
}
}
}
sql1 = sql1.Substring(0, sql1.Length - 1); //去掉最后一个","号
foreach (DataColumn col in dt.Columns)
{
sql1 = sql1 + "," + col.ColumnName.ToString(); //获取列的列名
//MessageBox.Show(col.ColumnName.ToString());
}
1) 设定行高和列宽自动调整
[C#]
// 设定包括Header和所有单元格的列宽自动调整
DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
// 设定包括Header和所有单元格的行高自动调整
DataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells;
AutoSizeColumnsMode 属性的设定值枚举请参照 msdn 的 DataGridViewAutoSizeRowsMode 说明
2)指定列或行自动调整
[C#]
// 第一列自动调整
DataGridView1.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells;
AutoSizeMode 设定为 NotSet 时, 默认继承的是 DataGridView.AutoSizeColumnsMode 属性。
3) 设定列头的高度和行头的宽度自动调整
[C#]
// 设定列头的宽度可以自由调整
DataGridView1.ColumnHeadersHeightSizeMode =
DataGridViewColumnHeadersHeightSizeMode.AutoSize;
// 设定行头的宽度可以自由调整
DataGridView1.RowHeadersWidthSizeMode =
DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders;
4) 随时自动调整
a, 临时的,让列宽自动调整,这和指定AutoSizeColumnsMode属性一样。
[C#]
// 让 DataGridView1 的所有列宽自动调整一下。
DataGridView1.AutoResizeColumns(DataGridViewAutoSizeColumnsMode.AllCells);
// 让 DataGridView1 的第一列的列宽自动调整一下。
DataGridView1.AutoResizeColumn(0, DataGridViewAutoSizeColumnMode.AllCells);
上面调用的 AutoResizeColumns 和 AutoResizeColumn 当指定的是DataGridViewAutoSizeColumnMode.AllCells 的时候, 参数可以省略。即:
DataGridView1.AutoResizeColumn(0) 和 DataGridView1.AutoResizeColumns()
b,临时的,让行高自动调整
[C#]
// 让 DataGridView1 的所有行高自动调整一下。
DataGridView1.AutoResizeRows(DataGridViewAutoSizeRowsMode.AllCells);
//让 DataGridView1 的第一行的行高自动调整一下。
DataGridView1.AutoResizeRow(0, DataGridViewAutoSizeRowMode.AllCells);
上面调用的 AutoResizeRows 和 AutoResizeRow 当指定的是DataGridViewAutoSizeRowMode.AllCells 的时候, 参数可以省略。即:DataGridView1.AutoResizeRow(0) 和 DataGridView1.AutoResizeRows()
c,临时的,让行头和列头自动调整
关于性能:
通过 AutoSizeColumnsMode 或者 AutoSizeRowsMode 属性所指定的单元格进行自动调整时,如果调整次数过于多那么将可能导致性能下降,尤其是在行和列数比较多的情况下。在这时用 DisplayedCells 代替 AllCells 能减少非所见的单元格的调整,从而提高性能。
[C#]
// 列头高度自动调整
DataGridView1.AutoResizeColumnHeadersHeight();
// 行头宽度自动调整
DataGridView1.AutoResizeRowHeadersWidth(
DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders);