您的位置:首页 > 编程语言 > C#

C#学习与上位机开发之文件操作(EXCEL保存案例)

2017-05-05 21:55 537 查看
【功能目标】

1、外部插件使用学习

2、对数据进行EXCEL保存

【效果图】

效果图如下所示:







【代码讲解】

1、添加引用

首先在资源管理器中添加引用,如下图所示。右击添加引用

再到扩展里面寻找需要用到的插件。

譬如我们使用EXCEL插件







如下图所示(EXCEL插件)

此时你就可以再程序中调用EXCEL了。





2、创建新建文件窗口

此处需要用到一个类SaveFileDialog

相关介绍参考官方文件

https://msdn.microsoft.com/zh-cn/library/system.windows.forms.savefiledialog.aspx

我们需要掌握的总结如下

//可能要获取的路径名
string localFilePath = "", fileNameExt= "", newFileName= "", FilePath = "";
SaveFileDialog saveFileDialog = new SaveFileDialog();
//设置文件类型
//书写规则例如:txt files(*.txt)|*.txt
saveFileDialog.Filter = "txt files(*.txt)|*.txt|xls files(*.xls)|*.xls|All files(*.*)|*.*";
//设置默认文件名(可以不设置)
saveFileDialog.FileName = "siling-Data";
//主设置默认文件extension(可以不设置)
saveFileDialog.DefaultExt = "xml";
//获取或设置一个值,该值指示如果用户省略扩展名,文件对话框是否自动在文件名中添加扩展名。(可以不设置)
saveFileDialog.AddExtension = true;
//设置默认文件类型显示顺序(可以不设置)
saveFileDialog.FilterIndex = 2;
//保存对话框是否记忆上次打开的目录
saveFileDialog.RestoreDirectory = true;
// Show save file dialog box
DialogResult result = saveFileDialog.ShowDialog();
//点了保存按钮进入
if (result == DialogResult.OK)
{
//获得文件路径
localFilePath = saveFileDialog.FileName.ToString();
//获取文件名,不带路径
//fileNameExt = localFilePath.Substring(localFilePath.LastIndexOf("\\") + 1);
//获取文件路径,不带文件名
//FilePath = localFilePath.Substring(0, localFilePath.LastIndexOf("\\"));
//给文件名前加上时间
//newFileName = DateTime.Now.ToString("yyyyMMdd") + fileNameExt;
//在文件名里加字符
//saveFileDialog.FileName.Insert(1,"dameng");
//为用户使用 SaveFileDialog 选定的文件名创建读/写文件流。
//System.IO.FileStream fs = (System.IO.FileStream)saveFileDialog.OpenFile();//输出文件
//fs可以用于其他要写入的操作
}

设计代码如下

private string ShowSaveFileDialog()
{
string localFilePath = "";// fileNameExt, newFileName, FilePath;
SaveFileDialog sfd = new SaveFileDialog();//保存文件窗口
//设置文件类型
sfd.Filter = "Excel文件(*.xlsx)|*.xlsx";//保存类型为EXCEL
//保存对话框是否记忆上次打开的目录
sfd.RestoreDirectory = true;

//点了保存按钮进入
if (sfd.ShowDialog() == DialogResult.OK)
{
localFilePath = sfd.FileName.ToString(); //获得文件路径
//string fileNameExt = localFilePath.Substring(localFilePath.LastIndexOf("\\") + 1); //获取文件名,不带路径

//获取文件路径,不带文件名
//FilePath = localFilePath.Substring(0, localFilePath.LastIndexOf("\\"));

}
return localFilePath;//返回值为地址
}

3、文件写入

介绍一个Application类

Microsoft.Office.Interop.Excel.Application - 就是我们的excel应用程序类。

Workbook - 就是我们平常见的一个个excel文件,经常是使用Workbooks类对其进行操作。

Worksheet - 就是excel文件中的一个个sheet页。

Worksheet.Cells[row, column] - 就是某行某列的单元格,注意这里的下标row和column都是从1开始的,跟我平常用的数组或集合的下标有所不同。

首先创建一个EXCEL文档,调用上面我们做得那个方法。

然后新建一个EXCEL类,然后操作如下程序所示

private void Btn_DataSave_Click(object sender, EventArgs e)
{//数据存储
/*******************数据导入Excel**********************/
string fileName = ShowSaveFileDialog(); //文件的保存路径和文件名
try
{
// 创建Excel文档类
Microsoft.Office.Interop.Excel.Application ExcelApp = new Microsoft.Office.Interop.Excel.Application();
//创建EXCEL文档

Microsoft.Office.Interop.Excel.Workbook ExcelDoc = ExcelApp.Workbooks.Add(Type.Missing);
// 创建一个EXCEL页
Microsoft.Office.Interop.Excel.Worksheet xlSheet = ExcelDoc.Worksheets.Add(Type.Missing,
Type.Missing, Type.Missing, Type.Missing);
ExcelApp.DisplayAlerts = false;

// 单元格下标是从[1,1]开始的
xlSheet.Cells[1, 1] = "序号";
xlSheet.Cells[1, 2] = "电压";
xlSheet.Cells[1, 3] = "SOC";
xlSheet.Cells[1, 4] = "SOH";
xlSheet.Cells[1, 5] = "温度";
//遍历存数据
for (int i = 0; i < 100; i++)
{
xlSheet.Cells[i + 2, 1] = "电池" + i.ToString();
}
for (int i = 0; i < 100;i++ )
{
xlSheet.Cells[i + 2, 2] = Voltage_Battery[i].Text;
}
for (int i = 0; i < 100; i++)
{
xlSheet.Cells[i + 2, 3] = Soc_Battery[i].Text;
}
for (int i = 0; i < 100; i++)
{
xlSheet.Cells[i + 2, 4] = Soh_Battery[i].Text;
}

// 文件保存完毕输出信息

//将此页保存到我们新建的文档中
xlSheet.SaveAs(fileName);

//释放EXCEL资源
ExcelDoc.Close(Type.Missing, fileName, Type.Missing);
ExcelApp.Quit();
MessageBox.Show("数据保存成功!");
}
catch
{
MessageBox.Show("数据保存失败!");
}
}

更多介绍参考

https://wenku.baidu.com/view/a753ecc4b4daa58da1114a5e.html

详细代码请到我的GitHub上获取

https://github.com/Harryjun/BMS
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐