C#中获取文件路径、DataGridView显示行号

来源:百度文库 编辑:神马文学网 时间:2024/06/13 00:52:24
我现在添加了一个textbox控件,在添加了一个button,我希望完成的是当点击Button的时候就弹出对话框,选择需要打开的文件,选择文件确定后,该文件的路径就复制到textbox中。
button的click事件里的代码这样写就OK了
OpenFileDialog ofd = new OpenFileDialog();
ofd.Title = "打开";
ofd.Filter="所有文件|*.*";  这是设置扩展名。
if (ofd.ShowDialog() == DialogResult.OK)
{
TextBox1.text = ofd.FileName;
}
C#,怎样得到本文件当前所在路径?
private void button1_Click(object sender, System.EventArgs e)
{
string strPath = Application.StartupPath;
textBox1.Text = strPath ;
}
生成后的exe文件在什么目录,strPath就是那个目录名
DataGridView显示行号的几种方法
文章录入:7747.Net    责任编辑:7747.Net  194
【字体:小 大】
方法一:
网上最常见的做法是用DataGridView的RowPostPaint事件在RowHeaderCell中绘制行号:
RowPostPaint
private void dataGridView1_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e)        {            try            {                //添加行号                 SolidBrush v_SolidBrush = new SolidBrush(dataGridView1.RowHeadersDefaultCellStyle.ForeColor);                int v_LineNo = 0;                v_LineNo = e.RowIndex + 1;                string v_Line = v_LineNo.ToString();                e.Graphics.DrawString(v_Line, e.InheritedRowStyle.Font, v_SolidBrush, e.RowBounds.Location.X + 15, e.RowBounds.Location.Y + 5);            }            catch (Exception ex)            {                MessageBox.Show("添加行号时发生错误,错误信息:" + ex.Message, "操作失败");            }        }
但是这种方法在大数据量的时候性能比较差,每次滚动数据都会触发RowPostPaint事件。
方法二:
我的做法是给每行的HeaderCell赋值。
在网上发现有人提到这种做法,但是因为最后的显示问题而选择了上面的方法。具体问题就是,在行号超过2位,如100、1000,在选中该行时,DataGridView的行指示符?会把行号往右挤,导致现实不全,100的时候显示? 10。
其实还是RowsHeaderWidth的大小有问题,将该列的宽度放大,行号显示的也没问题!
不知道他们有没有试过,上面绘制行号的方法在大行号的情况下显示也会有问题。
既然知道问题所在就要找到相应的解决方法。
具体做法是将DataGridView的RowsHeaderWidthSizeMode属性 设置为AutoSizeToAllHeaders或者AutoSizeToDisplayedHeaders,这样自动设置宽度就不会出现行指示符挤压行号的情况了。
对于每次DataGridView的行变化,我们都去更新行号,用RowsAdded和RowsRemoved事件。
代码如下:
RowsAdded & RowsRemoved
private void DataGridView1_RowsAdded(object sender, DataGridViewRowsAddedEventArgs e)        {            for (int i = 0; i < e.RowCount; i++)            {                this.DataGridView1.Rows[e.RowIndex + i].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight;                this.DataGridView1.Rows[e.RowIndex + i].HeaderCell.Value = (e.RowIndex + i + 1).ToString();            }            for (int i = e.RowIndex + e.RowCount; i < this.DataGridView1.Rows.Count; i++)            {                this.DataGridView1.Rows[i].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight;                this.DataGridView1.Rows[i].HeaderCell.Value = (i + 1).ToString();            }        }        private void DataGridView1_RowsRemoved(object sender, DataGridViewRowsRemovedEventArgs e)        {            for (int i = 0; i < e.RowCount; i++)            {                this.DataGridView1.Rows[e.RowIndex + i].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight;                this.DataGridView1.Rows[e.RowIndex + i].HeaderCell.Value = (e.RowIndex + i + 1).ToString();            }            for (int i = e.RowIndex + e.RowCount; i < this.DataGridView1.Rows.Count; i++)            {                this.DataGridView1.Rows[i].HeaderCell.Style.Alignment = DataGridViewContentAlignment.MiddleRight;                this.DataGridView1.Rows[i].HeaderCell.Value = (i + 1).ToString();            }        }