`
baobeituping
  • 浏览: 1064724 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

C#中DataGridView控件60招

    博客分类:
  • .NET
 
阅读更多

1. DataGridView当前的单元格属性取得、变更

2. DataGridView编辑属性

3. DataGridView最下面一列新追加行非表示

4. DataGridView判断当前选中行是否为新追加的行

5. DataGridView删除行可否设定

6. DataGridView行列不表示和删除

7. DataGridView行列宽度高度设置为不能编辑

8. DataGridView行高列幅自动调整

9. DataGridView指定行列冻结

10. DataGridView列顺序变更可否设定

11. DataGridView行复数选择

12. DataGridView选择的行、列、单元格取得

13. DataGridView指定单元格是否表示

14. DataGridView表头部单元格取得

15. DataGridView表头部单元格文字列设定

16. DataGridView选择的部分拷贝至剪贴板

17. DataGridView粘贴

18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息)

19. 设置DataGridView的行头和文本居中


1.当前的单元格属性取得、变更

 [C#]

 '当前选中单元的值

 Console.WriteLine(DataGridView1.CurrentCell.Value)

 '当前列的Index值

 Console.WriteLine(DataGridView1.CurrentCell.ColumnIndex)

 '当前单元的行Index值

 Console.WriteLine(DataGridView1.CurrentCell.RowIndex)

 '将控件中(0, 0)处的值,赋给当前单元格.

 DataGridView1.CurrentCell =DataGridView1[0, 0]

2.DataGridView编辑属性

全部单元格编辑属性

 [C#]

 'DataGridView1只读属性

 DataGridView1.ReadOnly = True

 指定行列单元格编辑属性

[C#]
 DataGridView1.Columns[1]ReadOnly = True

 DataGridView1.Rows[2].ReadOnly = True

 DataGridView1[0, 0].ReadOnly = True

 根据条件判断单元格的编辑属性

下例中column2的值是True的时候,Column1设为可编辑
[C#]
 代码
 private void DataGridView1_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
   {
       if (this.DataGridView1.Columns[e.ColumnIndex].Name.ToString().Equals("Column2"))
       {
    if (DataGridView1["Column2", e.RowIndex].Value.ToString().ToLower().Equals("true"))
    {
        DataGridView1["Column1", e.RowIndex].ReadOnly = false;
    }
    else
    {
        DataGridView1["Column1", e.RowIndex].ReadOnly = true;
    }
       }
   }

 


3.DataGridView最下面一列新追加行非表示
[C#]
 DataGridView1.AllowUserToAddRows = False


4.判断当前选中行是否为新追加的行
[C#]
 if (DataGridView1.CurrentRow.IsNewRow)
 {
  Console.WriteLine("当前行,是新添加的行");
 }
 else
 {
  Console.WriteLine("当前行,不是新添加的行");
 }

5. DataGridView删除行可否设定

[C#]

 DataGridView1.AllowUserToDeleteRows = False

根据条件判断当前行是否要删除

[C#]

代码
 private void DataGridView1_UserDeletingRow(object sender, DataGridViewRowCancelEventArgs e)
          {
              if (MessageBox.Show("确定要删除吗?", "删除确认", MessageBoxButtons.OKCancel, MessageBoxIcon.Question).Equals(System.Windows.Forms.DialogResult.OK))
              {
 
              }
              else
              {
                  e.Cancel = true;
              }
          }


6. DataGridView行列不表示和删除

行列不表示

[C#]

 'DataGridView1的第一列不表示

 DataGridView1.Columns[0].Visible = False

 'DataGridView1的第一行不表示

 DataGridView1.Rows[0].Visible = False

行列表头部分不表示

[C#]
 DataGridView1.ColumnHeadersVisible = False

 DataGridView1.RowHeadersVisible = False

指定行列删除

[C#]
 DataGridView1.Columns.Remove("Column1")

 DataGridView1.Columns.RemoveAt(0)

 DataGridView1.Rows.RemoveAt(0)

选择的行列删除(多行列)

[C#]
 'DataGridView1删除选中的行

 foreach (DataGridViewRow r in DataGridView1.SelectedRows)
       {
    if (!r.IsNewRow)
    {
        DataGridView1.Rows.Remove(r);
    }
       }


7. DataGridView行列宽度高度设置为不能编辑

[C#]

'DataGridView1的列的宽设为不能编辑


 DataGridView1.AllowUserToResizeColumns = False

 'DataGridView1的行的高设为不能编辑

 DataGridView1.AllowUserToResizeRows = False

指定行列宽度高度设置为不能编辑

[C#]

 'DataGridView1指定列宽度设置为不能编辑

 DataGridView1.Columns[0].Resizable = DataGridViewTriState.False

 'DataGridView1指定行高度设置为不能编辑

 DataGridView1.Rows[0].Resizable = DataGridViewTriState.False

列幅行高最小值设定

[C#]

 '列幅最小值设定为100

 DataGridView1.Columns[0].MinimumWidth = 100

 '行高最小值设定为50

 DataGridView1.Rows[0].MinimumHeight = 50

 行列表头部分行高列幅设置为不能编辑

[C#]

 行列表头部分行高设置为不能编辑 

 DataGridView1.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.DisableResizing

 行列表头部分列幅设置为能编辑

 DataGridView1.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.EnableResizing

8. DataGridView行高列幅自动调整
[C#]

 根据内容,列幅自动调整

 DataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells

 根据内容,行高自动调整

 DataGridView1.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells

 表头部分行高列幅自动调整

[C#]

 '表头列高自动调整

 DataGridView1.ColumnHeadersHeightSizeMode = DataGridViewColumnHeadersHeightSizeMode.AutoSize

 '表头行幅自动调整

 DataGridView1.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders

 指定列自动调整

[C#]

 '指定列的列幅自动调整

 DataGridView1.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.DisplayedCells

9. DataGridView指定行列冻结

列冻结(当前列以及左侧做所有列)

[C#]

 'DataGridView1的左侧2列固定

 DataGridView1.Columns[1].Frozen = True

行冻结(当前行以及上部所有行)

[C#]

 'DataGridView1的上部2行固定

 DataGridView1.Rows[2].Frozen = True

指定单元格冻结(单元格所在行上部分所有行,列左侧所有列)

[C#]

 DataGridView1[0, 0]. Frozen = True

10. DataGridView列顺序变更可否设定

[C#]

 'DataGridView1的列的位置设定为允许改变

 DataGridView1.AllowUserToOrderColumns = True

 但是如果列冻结的情况下,冻结的部分不能变更到非冻结的部分。

 变更后列位置取得

[C#]

 '取得列"Column1"现在的位置

 Console.WriteLine(DataGridView1.Columns["Column1"].DisplayIndex)

 '列"Column1"移动到最前面

 DataGridView1.Columns["Column1"].DisplayIndex = 0

11. DataGridView行复数选择

不可选择多行

[C#]

 'DataGridView1不可选择多行

 DataGridView1.MultiSelect = False

单元格选择的时候默认为选择整行

[C#]

'单元格选择的时候默认为选择整行

 DataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect

12. DataGridView选择的行、列、单元格取得

[C#]

'输出选择的单元格位置

 Console.WriteLine("选择的单元格位置")

 foreach (DataGridViewCell c in DataGridView1.SelectedCells)
 {
       Console.WriteLine(c.ColumnIndex + "," + c.RowIndex);
 }

'输出选择的行位置

 Console.WriteLine("选择的行位置")

 foreach (DataGridViewRow r in dgvBeforeStep.SelectedRows)
 {
       Console.WriteLine(r.Index);
 }

''输出选择的列位置

 foreach (DataGridViewColumn col in dgvBeforeStep.SelectedColumns)
 {
    Console.WriteLine(col.Index);
 }

指定行、列、单元格取得

[C#]

 '(0, 0)的选中

 DataGridView1[0, 0].Selected = True

 'Index为1的行选中

 DataGridView1.Rows[1].Selected = True

 'Index为2的列选中

 DataGridView1.Columns[2].Selected = True


13. DataGridView指定单元格是否表示

[C#]
 if (DataGridView1 [2,0].Displayed&& DataGridView1 [2,0].Visible)
 {
      DataGridView1.CurrentCell = DataGridView1[2,0];
 }


14. DataGridView表头部单元格取得

[C#]
 'DataGridView1第一列表头改变

 DataGridView1.Columns[0].HeaderCell.Value = "第一列"

 'DataGridView1第一行表头改变

 DataGridView1.Rows[0].HeaderCell.Value = "第一行"

 'DataGridView1左上角单元格值改变

 DataGridView1.TopLeftHeaderCell.Value = "左上"

15. DataGridView表头部单元格文字列设定

更改列Header表示文字列

[C#]

 'DataGridView1改变第一列头部单元格文字

 DataGridView1.Columns[0].HeaderText = "第一列"

更改行Header表示文字列

[C#]

 'DataGridView1行的头部单元格为序号

 for (int i = 0; i < DataGridView1.Rows.Count-1; i++)
 {
      DataGridView1.Rows[i].HeaderCell.Value=i.ToString();
 }

 

'行的宽度自动调节

 DataGridView1.AutoResizeRowHeadersWidth( DataGridViewRowHeadersWidthSizeMode.AutoSizeToAllHeaders)

最左上Header单元格文字列

[C#]

'修改最左上单元格

 DataGridView1.TopLeftHeaderCell.Value = "/"

16. DataGridView选择的部分拷贝至剪贴板

拷贝模式设定

[C#]

 DataGridView1.ClipboardCopyMode = DataGridViewClipboardCopyMode.EnableWithoutHeaderText

选中部分拷贝

[C#]
 Clipboard.SetDataObject(DataGridView1.GetClipboardContent())

17.DataGridView粘贴

[C#]

代码
 if (DataGridView1.CurrentCell.Value == null)
 {
      return;
 }
 int insertRowIndex = DataGridView1.CurrentCell.RowIndex;
 string pasteText=Clipboard.GetText();
 if(string.IsNullOrEmpty(pasteText))
 {
      return;
 }
 string[] lines=pasteText.Split('\r');
 bool isHeader=true;
 foreach(string line in lines)
 {   
      if(isHeader)
      {
   isHeader=false;
      }
      else
      {
   string[] vals=line.Split('\t');
   if (vals.Length - 1 != DataGridView1.ColumnCount)
   {
       throw new ApplicationException("列数错误");
   }
   DataGridViewRow row = DataGridView1.Rows[insertRowIndex];
   row.HeaderCell.Value=vals[0];
   for(int i=0;i<row.Cells.Count-1;i++)
   {
       row.Cells[i].Value=vals[(i+1)];
   }
   insertRowIndex+=1;
  }
 }

 

18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息)

[C#]

指定单元格

 DataGridView1[0, 0].ToolTipText = "指定单元格"

指定列

 DataGridView1.Columns[0].ToolTipText = "指定列"

指定行

 DataGridView1.Rows[0].HeaderCell.ToolTipText = "指定行"

 CellToolTipTextNeeded事件,在多个单元格使用相同的ToolTips的时候,可以用该事件,下例为显示当前单元格的行号和列号

[C#]

 'CellToolTipTextNeeded事件

 private void DataGridView1_CellToolTipTextNeeded(object sender, DataGridViewCellToolTipTextNeededEventArgs e)
 {
      e.ToolTipText = e.RowIndex.ToString() + "," + e.ColumnIndex.ToString();
 }
 
 19. 设置DataGridView的行头和文本居中
 设置ColumnHeadersDafaultCellStyle属性的Alignment为MiddleCenter(行头居中)
 设置DefalutCellStyle属性的Alignment为MiddleCenter(文本居中)

 

 

例如:

ServerGrid.DataSource = serverList;
            ServerGrid.Columns[0].HeaderCell.Value = "编码";
            ServerGrid.Columns[1].HeaderCell.Value = "页号";
            ServerGrid.Columns[2].HeaderCell.Value = "控件号";
            ServerGrid.Columns[3].HeaderCell.Value = "名称";
            ServerGrid.ColumnHeadersDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            ServerGrid.DefaultCellStyle.Alignment = System.Windows.Forms.DataGridViewContentAlignment.MiddleCenter;

分享到:
评论

相关推荐

    基于C#的WinForm中DataGridView控件操作汇总

    "基于C#的WinForm中DataGridView控件操作汇总" 在C#的WinForm中,DataGridView控件是一种常见的控件,用于显示和编辑表格数据。下面将对DataGridView控件的操作进行汇总。 一、单元格内容的操作 在DataGridView...

    C#里面DataGridView控件数据打印

    本文将深入探讨如何在C#中利用DataGridView控件进行数据打印,包括如何处理包含条形码的打印需求。 首先,我们要了解DataGridView控件的基本用法。在C#中,通过Visual Studio的工具箱,可以将DataGridView拖放到...

    C#中DataGridView控件DateTime列插入DateTimePicker

    1. **创建DataGridView**:在你的C#代码中,首先需要实例化一个DataGridView控件,并将其添加到窗体上。你可以通过Visual Studio的设计器或者在代码中动态创建。 2. **添加自定义列**:由于没有内置的DateTime列,...

    C# datagridView 控件使用心得

    本篇文章将深入探讨C#中datagridview控件的使用心得,包括其基本功能、数据绑定、自定义操作和事件处理等方面。 首先,datagridview控件的基本功能强大,它支持行列显示、排序、过滤、编辑等操作。在设计阶段,我们...

    C#打印 DataGridView 控件

    近段时间看到很多在路上的朋友都在找这个 我也偶尔在别的地方下载来看了下别人写的东西 感觉不是这缺就是那少 都不大完美 这段 C# DataGridView 控件内容打印代码 是经本人在VS2008下测试通过 可以实现对...

    C#_DataGridView控件使用全攻略

    C# DataGridView控件使用完全攻略 DataGridView是用于Windows Froms 2.0的新网格控件。它可以取代先前版本中DataGrid控 件,它易于使用并高度可定制,支持很多我们的用户需要的特性。 关于本文档: 本文档不准备...

    在C#中使用控件DataGridView实现数据库增删改查

    在 C# 中使用控件 DataGridView 实现数据库增删改查 在 C# 中使用控件 DataGridView 实现数据库增删改查是指在 Windows 窗体应用程序中使用 DataGridView 控件来实现对数据库的增删改查操作。下面将详细介绍实现该...

    c# Datagridview 分页控件以及测试程序

    在Windows桌面应用中,数据展示是常见的需求,而DataGridView控件是C#中用于展示大量结构化数据的强大工具。本篇将详细介绍"C# Datagridview 分页控件以及测试程序"的相关知识点,并提供实现分页功能的思路。 1. ...

    C#中改变DataGridView控件边框颜色的方法

    在C#编程中,`DataGridView`控件是一个用于显示数据表格的强大工具,广泛应用于各种桌面应用程序。默认情况下,它的边框颜色可能并不符合所有开发者或用户对于界面美观的要求。因此,有时我们需要自定义控件的外观,...

    C#DataGridView自定义控件的列,提供源代码!

    现有的几种嵌套控件,但无时间控件类型,下载代码中就是嵌套了时间控件类。 System.Windows.Forms.DataGridViewTextBoxColumn, System.Windows.Forms.DataGridViewComboBoxColumn, System.Windows.Forms....

    C#实现DataGridView控件行列互换的方法

    在C#编程中,DataGridView控件是一个非常常用的组件,用于展示和编辑表格数据。当需要对数据进行特殊处理,如行列互换时,就需要利用到控件的一些高级特性。本篇将详细介绍如何在C#中实现DataGridView控件的行列互换...

    C# DataGridView控件使用全攻略

    ### C# DataGridView 控件使用全攻略 #### 一、何为 DataGridView **1.1 DataGridView 和 DataGrid 之间的区别** DataGridView 控件是 .NET Framework 2.0 中引入的一个全新的表格控件,用来替代之前的 DataGrid ...

    C# .Net DataGridView控件使用大全

    C# .Net DataGridView控件使用大全(含有代码演示)

    c#中向DataGridView控件中添加合计、平均值、最大值、最小值

    在C#编程中,`DataGridView`控件是一个非常常用的数据展示工具,它允许开发者以表格形式展示数据。在处理大量数据时,为了更好地理解和分析,我们往往需要计算这些数据的统计值,比如合计、平均值、最大值和最小值。...

    winform(c#) DataGridView控件多维合并表头(有使用教程)

    本文将深入探讨如何在C#的WinForm环境中使用`DataGridView`控件实现多维表头的合并,并提供一个简单的教程。 首先,我们需要了解`DataGridView`的基本用法。它是.NET Framework中的一个控件,可以用来显示表格数据...

    C# DataGridView控件使用例子

    在.NET框架中,C#的DataGridView控件是一个强大的数据展示工具,它允许用户在Windows Forms应用程序中以表格形式查看和编辑数据。这个控件适用于多种数据源,包括数组、列表、数据库以及XML文件等。本教程将深入探讨...

    C#中datagridview使用tooltip控件显示单元格内容的方法

    在C#编程中,`DataGridView`控件是一个非常常用的组件,用于展示表格数据。当单元格内容过多,无法完全在网格内显示时,可以利用`Tooltip`控件来辅助显示这些隐藏的信息。以下是对`DataGridView`结合`Tooltip`控件在...

    C# DatagridView 多行列头的自定义控件

    在C#中,自定义控件通常通过继承现有的`DataGridView`控件并扩展其功能来完成。这涉及到重写或添加方法、属性和事件处理程序,以实现所需的特定行为。在这个案例中,开发者创建了一个自定义控件,使`DataGridView`...

Global site tag (gtag.js) - Google Analytics