当前位置: 首页 > wzjs >正文

网站如何做外部链接网站开发工作安排

网站如何做外部链接,网站开发工作安排,网站开发目录规范,wordpress怎么充值C#—csv文件格式操作实例【在winform表格中操作csv】 实例一 实例效果 当在winform界面中点击读取按钮时 将csv中的所有数据读取出来放置在datagridview控件,可以在datagridview控件中编辑数据,当点击保存按钮时 将datagridview控件中的所有数据存储在…

C#—csv文件格式操作实例【在winform表格中操作csv】

实例一

实例效果

当在winform界面中点击读取按钮时 将csv中的所有数据读取出来放置在datagridview控件,可以在datagridview控件中编辑数据,当点击保存按钮时 将datagridview控件中的所有数据存储在csv格式文件中。

第一步UI界面搭建

第二步封装一个csv文件格式的操作类

public class CSVAPI
{/// <summary>/// 保存/// </summary>/// <param name="date"></param>/// <param name="data"></param>/// <param name="result"></param>/// <param name="fileName"></param>public void SaveData(string date,string data, string result,string fileName){using (StreamWriter sw2 = new StreamWriter(fileName, true, Encoding.Default)){StringBuilder sb = new StringBuilder();sb.Append(date).Append(",").Append(data).Append(",").Append(result + "\n");sw2.Write(sb.ToString());}}/// <summary>/// 读取CSV/// </summary>/// <returns></returns>public string ReadData(string fileName){StreamReader sr = new StreamReader(fileName, Encoding.Default);string s = sr.ReadToEnd(); // 读取数据sr.Close();sr.Dispose();return s;}
}

第三步实现按钮事件

public partial class Form1 : Form
{public Form1(){InitializeComponent();}CSVAPI csv = new CSVAPI();string filename = "./data.csv";/// <summary>/// 保存/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private void button1_Click(object sender, EventArgs e){if (dataGridView1.Rows.Count>0){//  写入表头(将表头写死)FileStream fs = new FileStream(filename, FileMode.Create, FileAccess.Write);StreamWriter sw = new StreamWriter(fs, Encoding.Default);StringBuilder sb = new StringBuilder(); // 定义可变字符串,保存存储的数据sb.Append("时间").Append(",").Append("姓名").Append(",").Append("事件");sw.WriteLine(sb);sw.Close();sw.Dispose();fs.Close();fs.Dispose();for (int i = 0; i < this.dataGridView1.RowCount-1; i++){csv.SaveData(this.dataGridView1.Rows[i].Cells[0].Value.ToString()+"", this.dataGridView1.Rows[i].Cells[1].Value.ToString() + "", this.dataGridView1.Rows[i].Cells[2].Value.ToString() + "", filename);}}}/// <summary>/// 读取/// </summary>/// <param name="sender"></param>/// <param name="e"></param>private void button2_Click(object sender, EventArgs e){this.dataGridView1.Rows.Clear();if (!File.Exists(filename)){MessageBox.Show("文件不存在");return;}string[] strings = csv.ReadData(filename).Split('\n');for (int i = 1;i < strings.Length;i++){if (!string.IsNullOrEmpty(strings[i])){string[] vals = strings[i].Split(',');this.dataGridView1.Rows.Add(vals);}}}
}

效果展示


实例二

实例效果

当在winform界面中点击读取按钮时弹出文件选择框,用户选择指定的csv文件然后将csv中的所有数据读取出来放置在datagridview控件,可以在datagridview控件中编辑数据,当点击保存按钮时 将datagridview控件中的所有数据存储在用户选择的csv格式文件路径中。

完整代码

public partial class Form1 : Form
{public Form1(){InitializeComponent();}OpenFileDialog ofd = new OpenFileDialog();//读取private void button1_Click(object sender, EventArgs e){//字符串-->dataTable--->dataSourceif(ofd.ShowDialog()==DialogResult.OK){FileStream fs = new FileStream(ofd.FileName, FileMode.Open);StreamReader sr = new StreamReader(fs,Encoding.Default);//读取文件流数据string data = "";//读出每一行的数据 "name ,age sex"string[] lines;// 数据的数组bool isHead = true; // 是否是表头DataTable dt = new DataTable();// 为了给datagridview设置数据源的类型while ((data=sr.ReadLine())!=null)  //先赋值给data 再判断data是否为空 ,不为空时候 一直读取{lines= data.Split(','); //把每一行的数据使用逗号分隔 [name ,age ,sex]if(isHead) //是不是表头[name ,age ,sex] {//遍历表头数组 给每一列添加标题for(int i = 0; i < lines.Length; i++){dt.Columns.Add(lines[i]); //设置dt的列的数据源}isHead = false;}else //不是表头数据,每一行表格添加数据{DataRow d1 = dt.NewRow();// 指定datatable创建行for (int i = 0; i < lines.Length; i++){d1[i] = lines[i];// 单元格设置值}dt.Rows.Add(d1);}}//绑定数据源if (dt.Rows.Count==0) //如果没行的 证明没数据{MessageBox.Show("没有数据","温馨提示");}else{//证明有数据 展示到控件上//dataGridView1.DataSource = dt;// dataGridView1.ColumnCount 列的个数dataGridView1.ColumnCount = dt.Columns.Count;//设置表头for (int i = 0; i < dt.Columns.Count; i++){// dataGridView1.Columns[i].HeaderText  表格控件的每一列的标题dataGridView1.Columns[i].HeaderText = dt.Columns[i].ColumnName;}//设置行数据for (int i = 0; i < dt.Rows.Count; i++){//dataGridView1.Rows. 设置表格控件的所有的行dataGridView1.Rows.Add(dt.Rows[i].ItemArray);}}sr.Close();fs.Close();}}// 保存private void button2_Click(object sender, EventArgs e){//dataSource-->dataTable--->stringDataTable dt  = new DataTable(); //创建dataTable类型//设置dt表头//遍历控件列的个数,根据控件的列的个数设置dt列for (int i = 0;i < dataGridView1.Columns.Count;i++){dt.Columns.Add(dataGridView1.Columns[i].HeaderText); //把控件列标题添加到dt列里面}//设置dt的行 for (int i = 0; i < dataGridView1.Rows.Count; i++) //遍历控件几行{DataRow row = dt.NewRow(); //创建行for (int j = 0; j < dataGridView1.Columns.Count; j++) //遍历控件几列{//dataGridView1[0,0] 根据几行几列取出表格数据row[j] = dataGridView1[j, i].Value;}dt.Rows.Add(row);}//把dt数据转成字符串进行写入SaveFileDialog sfd = new SaveFileDialog();sfd.Filter = "csv文件(*.csv)|.csv";if(sfd.ShowDialog()==DialogResult.OK){//开始写入FileStream fs = new FileStream(sfd.FileName, FileMode.Create);StreamWriter sw = new StreamWriter(fs,Encoding.Default);string data = "";// 写入的字符串//表头转成字符串for (int i = 0; i < dt.Columns.Count; i++){data += dt.Columns[i].ColumnName;// 把dt列标题取出拼接if(i <dt.Columns.Count-1){data += ","; // 列之间使用逗号隔开}}sw.WriteLine(data); //写入表头//写入行数据data = null;//防止表头数据重复写入for (int i = 0; i < dt.Rows.Count-1; i++){for (int j = 0; j <dt.Columns.Count; j++){data += dt.Rows[i][j]; //几行几列数据拼接dataif(j<dt.Columns.Count-1)//不是最后一列{data += ",";}}sw.WriteLine(data);//写入表数据data=null;}sw.Close();fs.Close();}}
}

 1 datagridview 控件的常用属性

  •    dataGridView1.Columns  表格控件的所有列
  •    dataGridView1.Columns .Count 表格控件的所有列的个数
  •    dataGridView1.Rows  表格控件的所有行
  •    dataGridView1[0,0] 根据几行几列取出表格数据
  •    dataGridView1.Columns[i].HeaderTex  表格控件的列的文本内容

2 dataTable常用的属性和方法

  •     DataTable dt  = new DataTable(); 创建dataTable类型
  •     DataRow row = dt.NewRow(); 创建一行
  •     dt.Rows.Add(row);  向dataTable添加一行
  •     dt.Columns.Add(); 向dataTable添加一列
  •     dt.Columns  datatable所有的列
  •     dt.Rows   datatable所有的行
  •     dt.Columns[i].ColumnName;列标题

http://www.dtcms.com/wzjs/545120.html

相关文章:

  • 做电影网站投资多少佛山微网站价格
  • 免费博客网站有哪些河南网站建设公司哪家好
  • dede 门户网站app登录wordpress
  • 在线考试网站开发中国影楼免费模板网
  • 网站底部浮动电话广告wordpress如何增加page样式
  • 乌镇网站建设标书如何建立一个网站视频教学
  • 宁波专业网站建设怎么做郑州网站建设求职简历
  • 家用电脑搭建网站北京轨道交通建设管理有限公司网站
  • 创建一个网站网站空间费用网站可以做库存吗
  • 瑞安网站制作做jsp网站时怎么预览
  • 什么是企业云网站建设视觉设计师和平面设计师的区别
  • 最权威的公文写作网站网上买手表哪个网站可以买到正品
  • h5网站开发流程网站添加在线留言
  • 东莞广告公司东莞网站建设网站备案中更名
  • wordpress站内信插件开发一个交易网站多少钱
  • 阿里网站建设费用优化用户体验
  • 自己创建一个网站需要多少钱网站开发 数据库对比
  • 做代刷网站赚钱不我的小程序怎么制作
  • 国外设计网站h开头wordpress 父分类
  • 建设个商城网站需要多少钱英文外贸网站建设
  • 如何设置手机网站主页网页解析技术流程
  • 益阳网站建设企业如何做网站优化的内容
  • 万网网站建设的子分类能显示多少个wordpress 安装 模板
  • 公司的网站建设计入什么科目举例一个成功的网络营销案例
  • 品牌网站建设小i蝌蚪网站上做旅游卖家要学什么
  • 建设银行新版网站上线企业邮箱域名
  • 网站开发常用问题用jsp建设网站
  • 什么是做自己的网站宜昌本地网站建设
  • 免费网站制作静态网页扩展名
  • 建一个网站需要哪些费用wordpress 免费 最好