- 浏览: 1041381 次
- 性别:
- 来自: 长沙
文章分类
- 全部博客 (639)
- 服务器配置篇 (58)
- hibernate篇 (14)
- spring篇 (33)
- struts篇 (28)
- JS篇 (46)
- 其他技术篇 (46)
- 数据库集群配置 (6)
- JAVA基础相关 (48)
- 分布式框架HadHoop的应用 (2)
- FLEX篇 (8)
- SQLSERVER技术 (32)
- Android学习 (13)
- amchart学习笔记 (1)
- openfire+smark搭建即时通讯 (9)
- Linux学习 (18)
- Oracle数据库 (15)
- 网站优化技术 (12)
- mysql数据库 (2)
- 项目学习总结 (18)
- 工具类(JAVA) (12)
- 工具类(JS) (2)
- 设计模式 (10)
- Lucene学习 (24)
- EJB3学习 (6)
- Sphinx搜索引擎 (3)
- 工作中用到的软件小工具 (5)
- .NET (49)
- JAVA 连接SQLSERVER2008步骤 (1)
- MongoDB (19)
- Android手机开发 (3)
- Maven (6)
- vue (9)
- Shiro (4)
- mybatis (3)
- netty框架 (1)
- SpringCloud (3)
- spring-cloud (7)
- Git (1)
- dubbo (2)
- springboot (13)
- rocketmq (1)
- git学习 (2)
- kafka服务器 (2)
- linux (10)
- WEB系统辅助项目 (1)
- jenkins (2)
- docker (4)
- influxdb (3)
- python (2)
- nginx (1)
最新评论
-
jiangfuofu555:
这样数据量大,效率怎么样?
sqlserver 实现分页的前台代码 以及后台的sqlserver语句 -
w156445045:
博主请问下,如何做到实时的刷新呢,
另外我后台是Java 谢谢 ...
web 版本的汽车仪表盘,非常好看。还有各种图形 -
jackyin5918:
<transportConnector name=&qu ...
ActiveMQ的activemq.xml详细配置讲解 -
握着橄榄枝的人:
你这个不是spring1.x的吧
spring1.x使用AOP实例 -
xiaophai:
全乱套了!
openfire+spark搭建完美的及时通讯
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程序如何与js交互
2012-07-15 22:28 2252一、建立网页 <html ... -
SQLITE FOR .NET4.0使用说明以及DLL
2012-06-28 22:07 1158SQLITE FOR .NET4.0使用说明以及DLL -
WinForm中TabControl的一些事件写法(C#)
2012-06-27 20:41 9826在TabControl控件中并没提供单个选项卡的Click事件 ... -
C# 通过字符串动态创建一个窗体
2012-06-27 20:27 1680private void button1_Click(obje ... -
vs2010 打包winform成EXE文件
2012-04-20 14:03 1566见附件 -
单击dataGridView某一行时将dataGridView当前选择行的某列值赋值给某个文本框
2012-01-13 09:19 2407SelectedRows和CurrentRow之间的区别 ... -
c# winform开发-datagridview开发
2012-01-13 09:18 1687datagridview 操作详解 目录: 1、 取得或 ... -
C# 中奇妙的函数. String Split 和 Join
2011-10-25 10:51 1054很多时候处理字符串数据,比如从文件中读取或者存入 - 我们可能 ... -
asp.net中web.config配置节点大全详解
2011-10-25 10:16 1330asp.net中web.config配置节点大全详解 2 ... -
Entity Framework in ASP.NET MVC Application (三)
2011-05-10 20:31 2427In the previous tutorial you im ... -
Entity Framework in ASP.NET MVC Application (二)
2011-05-10 20:29 1654In the previous tutorial you cr ... -
Entity Frame Work 4.1调用存储过程
2011-05-10 20:24 2067在这个问题上,琢磨了很久了。今天终于找到了调用的方法。 存储 ... -
entity-framework (code-first)实例开发(一)
2011-05-09 20:40 2708The Contoso University Web Appl ... -
使用ef4.1 的dbcontext进行数据库循环操作
2011-04-24 23:06 2205如果你想要调用一个类的方法进行循环操作:官方的例子: Dis ... -
使用EF 4.1的DbContext
2011-04-24 22:36 3598简述:EF4.1包括Code First和DbContext ... -
ADO.NET 访问存储过程
2011-04-24 22:15 1542ADO.NET 访问存储过程其实也比较简单,但是有些小细节部分 ... -
JAVA与.NET的相互调用——通过Web服务实现相互调用(附原代码)
2011-04-24 20:58 1256JAVA与.NET是现今世界竞争激烈的两大开发媒体,两者语言有 ... -
视图模式/视图->视图包
2011-04-24 20:16 1428ASP.NET MVC(自V1起)就支持一个带控制器和视图的V ... -
SkipRequestValidation] –> [AllowHtml]
2011-04-24 20:15 1383ASP.NET MVC内置了防止HTML和跨站脚本注入攻击的支 ... -
Log4net 详细说明
2011-04-12 22:29 1988在实际项目中我们经常 ...
相关推荐
C#_DataGridView控件使用全攻略
C# DataGridView控件使用全攻略
基于C#的WinForm中DataGridView控件操作汇总
近段时间看到很多在路上的朋友都在找这个 我也偶尔在别的地方下载来看了下别人写的东西 感觉不是这缺就是那少 都不大完美 这段 C# DataGridView 控件内容打印代码 是经本人在VS2008下测试通过 可以实现对...
主要介绍了C#中改变DataGridView控件边框颜色的方法,默认的DataGridView边框颜色很丑,本文用编程方法实现修改DataGridView边框颜色,需要的朋友可以参考下
现有的几种嵌套控件,但无时间控件类型,下载代码中就是嵌套了时间控件类。 System.Windows.Forms.DataGridViewTextBoxColumn, System.Windows.Forms.DataGridViewComboBoxColumn, System.Windows.Forms....
C# .Net DataGridView控件使用大全(含有代码演示)
主要介绍了C#实现DataGridView控件行列互换的方法,涉及C#中DataGridView控件元素遍历与添加操作的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
DataGridView中有文本框列,下拉框列,图像列,链接列,却没有DateTime列,这里实现在编辑DataGridView时可以录入DateTime类型数据。
在C#中使用控件DataGridView实现数据库增删改查
主要介绍了C#中datagridview使用tooltip控件显示单元格内容的方法,实例分析了C#控件的相关使用技巧,需要的朋友可以参考下
已经生成了DLL 直接拖入工具栏就可以使用了
用了一下午时间写的一个Datagridview分页控件,附上了控件所用的测试程序,希望对大家有所帮助。
这是最全面的C#-DataGridView控件介绍,包含DataGridView控件的各类属性介绍,搜索一下,你会发现会是你想要的那个PDF文档
实现文章内容
DataGridView控件使用例子,完全是代码的连接使用
winform(c#) DataGridView控件多维合并表头(有使用教程),从网上下载来的资料并不是很全,所以我自己动手做了个,效果很好,里面附有几个需要注意的地方的文档教程,方面大家掌握运用