WinForms C# 导入和导出 CSV 文件 Spread.NET

使用 WinForms C# 和 VB.NET 导入和导出 CSV 文件

2023 年 11 月 17 日
使用 Spread.NET 直接在 .NET WinForms 应用程序中处理 CSV 文件。

Spread.NET可帮助您创建电子表格、网格、仪表板和表单。它包括一个强大的计算引擎,具有 450 多个函数以及导入和导出 Microsoft Excel 电子表格的能力。开发人员可以利用广泛的 .NET 电子表格 API 和强大的计算引擎来创建分析、预算、仪表板、数据收集和管理、科学和财务应用程序。

在此博客中,MESCIUS 产品经理 Kevin Ashley 将带您完成使用 Spread.NET 导入和导出 CSV 文件中的数据所需的所有步骤,包括:

  • 创建/配置项目
  • 创建文件菜单
  • 创建/配置SplitContainer
  • 添加事件处理程序代码
  • ...以及更多!

将在运行时使用 Spread Designer 工具,只需一行代码即可在运行的应用程序中编辑 Excel 电子表格实例。最后,我将展示如何创建一个简单的前端电子表格用户界面,将 FpSpread 电子表格控件与 NameBox和 FormulaTextBox 控件集成,使用分割窗格创建主用户界面,以及如何实现菜单项来处理 文件 - C# 和 VB中的“打开”、“文件 - 保存”和 “文件 - 设计” 命令 。

以下是在 C# 和 VB.net WinForms 中导入和导出 CSV 文件的步骤:

  • 创建项目
  • 配置项目
  • 创建文件菜单
  • 创建SplitContainer1
  • 配置SplitContainer1
  • 创建SplitContainer2
  • 创建 FpSpread
  • 创建名称框
  • 创建公式文本框
  • 创建 WinForms 电子表格设计器组件
  • 为文件菜单项创建事件处理程序
  • 添加事件处理程序代码

这些步骤需要:

  • Microsoft Visual Studio 2022(注意:虽然这些步骤适用于 VS2022 和 .NET 6,但 Spread.NET WinForms 也可以在面向 .NET 4.6.2+ 的早期版本的 Visual Studio 中工作,遵循这些相同的步骤)
  • Spread.NET for WinForms(试用版或许可版)- 在此处获取 Spread.NET WinForms 的 30 天免费试用版 
 

第 1 步:创建项目

创建一个新项目

我们可以首先在Visual Studio 2022中创建一个新项目  ,选择 C#、Windows和 Desktop来筛选项目,然后选择C# 或 VB  WinForms App

第 2 步:配置项目

配置项目

输入 SpreadWinformsCSVIO作为 项目名称

第 3 步:创建文件菜单

现在,让我们添加一个MenuStrip。在 “工具箱” 窗口 ( F4 ) 的“菜单和工具栏”类别下,双击 MenuStrip组件以 在窗体中创建一个新的 MenuStrip :

菜单条工具箱

 

 通过使用关联的快捷键单击,创建 “文件 – 打开”、  “文件 – 保存”、  “文件 – 另存为”、  “文件 – 设计”和 “文件 – 退出”菜单项:

文件菜单

 

请注意, 文件 - 保存 菜单项最初应被禁用。菜单分隔符(  对菜单项文本使用“-”来创建菜单分隔符)和快捷键是可选的,但建议使用。我们将在稍后的步骤中为这些菜单项添加代码。

步骤4:创建SplitContainer1

注意: 使用 FpSpread 并不一定需要添加拆分器,但 SplitContainer 控件使创建友好且灵活的电子表格界面变得更加容易,因为它会自动处理电子表格、名称框和公式文本框控件的大小调整,而无需任何代码。

在 工具箱 ( CTRL+ALT+X ) 中,展开Containers类别 ,然后双击 SplitContainer 控件以创建 splitContainer1

 

拆分容器工具箱

步骤5:配置SplitContainer1

在 “属性” 窗口 ( F4 ) 中,对于 splitContainer1,将 Orientation设置 为 Horizo​​ntal,然后将 Panel1MinSize 和 SplitterDistance设置 为 23

SplitContainer 1 属性

 

电子表格将位于底部窗格中,编辑栏界面将位于顶部窗格中,拆分器将确定FormulaTextBox控件的高度,  以显示换行的长公式。

第6步:创建SplitContainer2

在 工具箱 ( CTRL+ALT+X ) 中,将新的SplitContainer拖放 到splitContainer1的  顶部窗格 ( Panel1 ) 内 以创建 splitContainer2

拆分容器 2

在 “属性” 窗口 ( F4 ) 中,对于 splitContainer2,将Panel1MinSize 和 SplitterDistance 设置  为 150

SplitContainer2 属性

第 7 步:创建 FpSpread

在 “解决方案资源管理器”中,展开 “解决方案 SpreadNetQuickStart” 和 “项目 SpreadNetQuickStart”,然后右键单击 “依赖项” 并选择 “管理 NuGet 包...”  (或按 ALT+P+N+N+N+ENTER):

管理 NuGet 包

 

然后,在NuGet Package Manager中,选择  左上角的 Browse ,然后 在搜索框中 键入Spread.WinForms以查找最新的GrapeCity.Spread.WinForms,然后单击 Install

NuGet 包管理器

 

安装 GrapeCity.Spread.WinForms后,继续安装 GrapeCity.Spread.WinForms.Design  – 该软件包包含 fpSpreadDesigner 组件,用于在运行时显示 Spread Designer 工具。

然后,在工具箱 ( CTRL+ALT+X ) 中,选择 FpSpread 控件:

 

FpSpread工具箱

最后,将FpSpread的实例绘制 到SplitContainer1的 底部窗格 ( Panel2 ) 中。当您创建控件时, Spread 设计器工具  可能会打开(这是默认行为) - 现在,  如果出现 ,请关闭Spread 设计器。

 

Fp传播形式

使用 属性网格 (F4),将 Dock 属性设置为 Fill:

 

FpSpread 扩展坞

第 8 步:创建名称框

在 工具箱 ( CTRL+ALT+X ) 中,展开GrapeCity Spread for WinForms的类别  ,然后选择 NameBox 控件:

名称框工具箱

 在左上角的 Panel1  ( SplitContiner2.Panel1 ) 内绘制一个新的 NameBox

姓名框表格

在 “属性” 窗口 ( F4 ) 中,对于 nameBox1,将Dock 设置  为 Fill

名称框属性

在nameBox1的右上角 ,单击指示器打开 NameBox Tasks,然后单击 AttachTo 下拉列表并选择 fpSpread1  – 这将以代码隐藏形式生成代码,以将 NameBox 控件附加到 FpSpread 控件:

 

名称框附件

第 9 步:创建 FormulaTextBox

在 工具箱 ( CTRL+ALT+X ) 中,展开 容器 并选择 面板 控件:

面板工具箱

 

在Panel2内 ( NameBox1 右侧 ),绘制一个新的 Panel

面板 2 表格

在 “属性” 窗口 ( F4 ) 中,对于 panel1,将BorderStyle 设置  为 FixSingle 并将 Dock设置 为 Fill

面板 1 属性

在 工具箱 (CTRL+ALT+X) 中, 选择 FormulaTextBox 控件:

公式文本框工具箱

在panel1  (位于 splitContainer2.Panel2内部)内 ,绘制一个新的FormulaTextBox 控件:

公式文本框表单

在 FormulaTextBox1 的属性 窗口 ( F4 ) 中,将BorderStyle 设置  为 None 并将 Dock设置 为 Fill

公式文本框属性

在FormulaTextBox1的右上角 ,单击指示器打开 FormulaTextBox 任务, 然后单击 AttachTo 下拉列表并选择 fpSpread1  – 这将以代码隐藏形式生成代码,以将 FormulaTextBox 控件附加到 FpSpread控件:

公式文本框附件

步骤 10:创建 WinForms 电子表格设计器组件

现在,在Toolbox 窗口 ( CTRL+ALT+X ) 的 GrapeCity Spread Design for WinForms 类别下  双击 FpSpreadDesigner组件以 在表单中 创建一个新的 FpSpreadDesigner :

FpSpread 设计器工具箱

刚刚添加的fpSpreadDesigner1组件  应显示在组件 menuStrip1 fpSpread1_Sheet1旁边的表单组件托盘中:

FpSpread 设计器表单

步骤 11:为文件菜单项创建事件处理程序

文件菜单处理程序设计

对于“文件”菜单中的每个菜单项  ,在设计视图中双击该菜单项,直到每个菜单项都有一个在 VB 或 C# 代码中生成的关联菜单处理程序:

文件菜单处理程序

第 12 步:添加事件处理程序代码

复制以下代码来实现事件处理程序:

[C#]

添加事件处理程序代码 C#

private string mFileName = null;private void openToolStripMenuItem_Click(object sender, EventArgs e)
{OpenFileDialog ofd = new OpenFileDialog();ofd.Filter = "CSV file (*.csv)|*.csv| All Files (*.*)|*.*";ofd.FilterIndex = 0;if (ofd.ShowDialog() == DialogResult.OK){mFileName = ofd.FileName;fpSpread1.Sheets[0].LoadTextFile(mFileName, FarPoint.Win.Spread.TextFileFlags.None, FarPoint.Win.Spread.Model.IncludeHeaders.None, "", ",", "");saveToolStripMenuItem.Enabled = true;}
}private void saveToolStripMenuItem_Click(object sender, EventArgs e)
{fpSpread1.Sheets[0].SaveTextFile(mFileName, FarPoint.Win.Spread.TextFileFlags.None, FarPoint.Win.Spread.Model.IncludeHeaders.None, "", ",", "");
}private void saveAsToolStripMenuItem_Click(object sender, EventArgs e)
{SaveFileDialog sfd = new SaveFileDialog();sfd.Filter = "CSV file (*.csv)|*.csv| All Files (*.*)|*.*";sfd.FilterIndex = 0;sfd.FileName = mFileName;if (sfd.ShowDialog() == DialogResult.OK){mFileName = sfd.FileName;fpSpread1.Sheets[0].SaveTextFile(mFileName, FarPoint.Win.Spread.TextFileFlags.None, FarPoint.Win.Spread.Model.IncludeHeaders.None, "", ",", "");saveToolStripMenuItem.Enabled = true;}
}private void designToolStripMenuItem_Click(object sender, EventArgs e)
{fpSpreadDesigner1.ShowDialog(fpSpread1);
}private void exitToolStripMenuItem_Click(object sender, EventArgs e)
{DialogResult ret = MessageBox.Show("Do you want to save this file before closing?", "Save Spreadsheet", MessageBoxButtons.YesNoCancel);if (ret == DialogResult.Cancel)return;else if (ret == DialogResult.Yes)saveToolStripMenuItem_Click(null, EventArgs.Empty);Close();
}
复制

[VB]

添加事件处理程序代码 VB

Private mFileName As String = NothingPrivate Sub OpenToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles OpenToolStripMenuItem.ClickDim ofd As New OpenFileDialogofd.Filter = "CSV file (*.csv)|*.csv| All Files (*.*)|*.*"ofd.FilterIndex = 0If ofd.ShowDialog() = DialogResult.OK ThenmFileName = ofd.FileNameFpSpread1.Sheets(0).LoadTextFile(mFileName, FarPoint.Win.Spread.TextFileFlags.None, FarPoint.Win.Spread.Model.IncludeHeaders.None, "", ",", "")SaveToolStripMenuItem.Enabled = TrueEnd If
End SubPrivate Sub SaveToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles SaveToolStripMenuItem.ClickFpSpread1.Sheets(0).SaveTextFile(mFileName, FarPoint.Win.Spread.TextFileFlags.None, FarPoint.Win.Spread.Model.IncludeHeaders.None, "", ",", "")
End SubPrivate Sub SaveAsToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles SaveAsToolStripMenuItem.ClickDim sfd As SaveFileDialog = New SaveFileDialog()sfd.Filter = "CSV file (*.csv)|*.csv| All Files (*.*)|*.*"sfd.FilterIndex = 0sfd.FileName = mFileNameIf sfd.ShowDialog() = DialogResult.OK ThenmFileName = sfd.FileNameFpSpread1.Sheets(0).SaveTextFile(mFileName, FarPoint.Win.Spread.TextFileFlags.None, FarPoint.Win.Spread.Model.IncludeHeaders.None, "", ",", "")SaveToolStripMenuItem.Enabled = TrueEnd If
End SubPrivate Sub DesignToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles DesignToolStripMenuItem.ClickFpSpreadDesigner1.ShowDialog(FpSpread1)
End SubPrivate Sub ExitToolStripMenuItem_Click(sender As Object, e As EventArgs) Handles ExitToolStripMenuItem.ClickDim ret As DialogResult = MessageBox.Show("Do you want to save this file before closing?", "Closing", MessageBoxButtons.YesNoCancel)If ret = DialogResult.Cancel ThenReturnElseIf ret = DialogResult.Yes ThenSaveToolStripMenuItem_Click(Nothing, EventArgs.Empty)End IfClose()
End Sub
复制

文件 - 打开的代码  使用 OpenFileDialog 浏览 CSV 文件,然后使用 FpSpread.Sheets.LoadTextFile方法打开选定的 CSV 文件。文件 - 保存的代码 使用 FpSpread.Sheets.SaveTextFile将电子表格数据保存到 CSV,文件- 另存为的代码 使用 SaveFileDialog 允许用户将文件保存到另一个位置或使用另一个名称。此功能允许 C# 或 VB.NET CSV 文件导入和导出。

File-Design 中的代码使用 FpSpreadDesigner.ShowDialog 方法在运行时显示 Spread Designer 工具,进行更改,然后将这些更改应用回表单中的电子表格实例。最后, “文件 - 退出”中的代码  提示用户是否保存文件,然后使用 Close 方法关闭窗体。

准备好构建和运行!

最终结果

该项目已准备好构建和运行。文件设计菜单将  在运行时打开Spread Designer工具,如上所示,它可以将更改应用于表单中运行的电子表格实例。了解 Spread .NET 如何让您能够在应用程序中使用 C# 或 VB.NET 将电子表格导入和导出为 CSV。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/198501.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【OpenCV】仿射变换中cv2.estimateAffine2D 的原理

目录 一、介绍 二、仿射变换矩阵 (M) 1.M中六个元素的说明 2.计算旋转角度 3.M的计算过程 三、输出状态 (inliers) 四、错切参数 一、介绍 cv2.estimateAffine2D 是 OpenCV 库中的一个函数,用于估计两个二维点集之间的仿射变换矩阵。即第一个点集经仿射变换转…

解决Requests中使用httpbin服务器问题:自定义URL的实现与验证

问题背景 在使用Python的Requests模块进行单元测试时,可能会遇到无法使用本地运行的httpbin服务器进行测试的问题。这是因为测试脚本允许通过环境变量HTTPBIN_URL指定用于测试的本地httpbin实例,但在某些测试用例中,URL是硬编码为httpbin.or…

成都瀚网科技有限公司抖音带货可靠么

近年来,随着抖音等短视频平台的兴起,越来越多的企业开始利用这些平台进行产品推广和销售。成都瀚网科技有限公司也紧跟这一趋势,通过抖音开展带货业务。那么,成都瀚网科技有限公司的抖音带货是否可靠呢?本文将对此进行…

KylinOSv10修改ulimit值

问题 ulimit 值过小,可能导致压力测试遇到瓶颈,比如通过nginx建立tcp长链接时,链接数量受限。需要修改ulimit值,Linux默认为1024。 解决 使用root或sudo权限,编辑文件/etc/security/limits.conf,新增以下…

pipeline + node +jenkins+kubernetes部署yarn前端项目

1、编写Dockerfile文件 # Set the base image FROM node:16.10.0# WORKDIR /usr/src/app/ WORKDIR /home/option# Copy files COPY ./ /home/option/# Build arguments LABEL branch${BRANCH} LABEL commit${COMMIT} LABEL date${BUILD_DATE} ARG ENV# Set ENV variables ENV …

基于C++实现循环赛日程表(分治算法)

一、问题描叙 设有n2^k个运动员,要进行网球循环赛。现在要设计一个满足以下要求的比赛日程表 每个选手必须与其他n-1个选手各赛一场每个选手一天只能赛一次循环赛一共进行n-1天 二、问题分析 按此要求可将比赛日程表设计成n行n-1列的表,在表中第 i 行…

金属压块液压打包机比例阀放大器

液压打包机是机电一体化产品,主要由机械系统、液压控制系统、上料系统与动力系统等组成。整个打包过程由压包、回程、提箱、转箱、出包上行、出包下行、接包等辅助时间组成。市场上液压打包机主要分为卧式与立式两种,立式废纸打包机的体积比较小&#xf…

Hive数据表操作--学习笔记

1,Hive数据表操作 1,建表语句和内外部表 ①创建内部表 create [external] table [if not exists] 表名( 字段名 字段类型 [comment 注释], 字段名 字段类型 [comment 注释], ... ) [row format delimited fields terminated by 指定分隔符];&#xff0…

如何简单挖掘公益SRC?

目录 1、寻找漏洞 1)谷歌语法 2)fofa 2、挖掘漏洞 3、提交报告 第一步:“标题”和“厂商信息”和“所属域名” 第二步:其它内容 第三步:复现步骤 0、IP域名归属证明 1、漏洞页 2、该干啥 3、注入的结果 4、上榜吉时 时间&#x…

【开源】基于JAVA的快递管理系统

项目编号: S 007 ,文末获取源码。 \color{red}{项目编号:S007,文末获取源码。} 项目编号:S007,文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、研究内容2.1 数据中心模块2.2 快递类型模块2.3 快…

Springboot 对于数据库字段加密方案(此方案是对字符串处理的方案)

背景:在erp开发中,有些用户比较敏感数据库里的数据比较敏感,系统给用户部署后,公司也不想让任何人看到数据,所以就有了数据库字段加密方案。 技术 spring boot mybatisplus 3.3.1 mybatisplus 实际提供了 字段加密方案 第一 他…

Java智慧工地SaaS管理平台源码:AI/云计算/物联网

智慧工地是指运用信息化手段,围绕施工过程管理,建立互联协同、智能生产、科学管理的施工项目信息化生态圈,并将此数据在虚拟现实环境下与物联网采集到的工程信息进行数据挖掘分析,提供过程趋势预测及专家预案,实现工程…

Elastic Search的RestFul API入门:index索引的增删改查

在我们开始深入探讨Elasticsearch的Restful API之前,有一点非常重要,那就是Elasticsearch存储的数据是JSON结构的。JSON,全称JavaScript Object Notation,是一种轻量级的数据交换格式,易于人阅读和编写,同时…

拜耳阵列(Bayer Pattern)以及常见彩色滤波矩阵(CFA)

一、拜耳阵列的来源 图像传感器将光线转化成电流,光线越亮,电流的数值就越大;光线越暗,电流的数值就越小。图像传感器只能感受光的强弱,无法感受光的波长。由于光的颜色由波长决定,所以图像传播器无法记录…

解决 VS2022 关于 c++17 报错: C2131 表达式必须含有常量值

使用 VS2022 编译 ORB-SLAM3 加载Vocabulary 二进制ORBvoc.bin 时,在 DBOW2 里修改 TemplatedVocabulary.h 代码显示这样的错误: 编译器错误 C2131 表达式的计算结果不是常数 定位到我的代码中: char buf [size_node] ; 原因 : …

Vatee万腾科技创新之舟:Vatee数字化力量引领未来的独特路径

在数字化的大潮中,Vatee万腾如一艘科技创新之舟,在未来的海洋中翱翔。vatee万腾以强大的数字化力量为桨,引领着行业向着新的、独特的路径前行,塑造着数字时代的未来。 Vatee万腾不仅仅是一家科技公司,更是一艘创新之舟…

(八)、基于 LangChain 实现大模型应用程序开发 | 基于知识库的个性化问答 (检索 Retrieval)

检索增强生成(RAG)的整体工作流程如下: 在构建检索增强生成 (RAG) 系统时,信息检索是核心环节。检索是指根据用户的问题去向量数据库中搜索与问题相关的文档内容,当我们访问和查询向量数据库时可能会运用到如下几种技术…

uni-app:前端实现心跳机制(全局)+局部页面控制心跳暂停和重新心跳

一、App.vue全局中写入心跳 在data中定义变量heartbeatTimer,便于暂停心跳使用在onLaunch中引用开始心跳的方法startHeartbeat()写入开始心跳方法写入暂停心跳方法写入请求后端刷心跳机制 定义变量 // 在全局设置的心跳机制中添加一个变量来保存定时器的标识 data(…

Find My蓝牙耳机|苹果Find My技术与耳机结合,智能防丢,全球定位

蓝牙耳机就是将蓝牙技术应用在免持耳机上,让使用者可以免除恼人电线的牵绊,自在地以各种方式轻松通话。自从蓝牙耳机问世以来,一直是行动商务族提升效率的好工具。正是应为蓝牙耳机小巧无线,人们越来越喜欢随身携带蓝牙耳机出门&a…

【论文阅读】基于隐蔽带宽的汽车控制网络鲁棒认证(一)

文章目录 Abstract第一章 引言1.1 问题陈述1.2 研究假设1.3 贡献1.4 大纲 第二章 背景和相关工作2.1 CAN安全威胁2.1.1 CAN协议设计2.1.2 CAN网络攻击2.1.3 CAN应用攻击 2.2 可信执行2.2.1 软件认证2.2.2 消息身份认证2.2.3 可信执行环境2.2.4 Sancus2.2.5 VulCAN 2.3 侧信道攻…