WPF SpreadSheetGear电子表单

简介: 我们经常会碰到生成Excel 界面并在其上操作的功能开发。 比如如下界面,我们需要在菜单里添加一个菜单按钮“Columns To Rows Transform" 功能是对多列批量转成多行. 我们可以通过Interop组件,在其中添加菜单附加功能,这个在之后的随笔中我会写个Demo,供大家查看。

 我们经常会碰到生成Excel 界面并在其上操作的功能开发。

比如如下界面,我们需要在菜单里添加一个菜单按钮“Columns To Rows Transform" 功能是对多列批量转成多行.

我们可以通过Interop组件,在其中添加菜单附加功能,这个在之后的随笔中我会写个Demo,供大家查看。但是这个有点麻烦,每次启动Excel都需要手动重新注册Excel环境。

 而我们可以通过第三方控件,提供解决方案:

1、安装Telerik控件

   如果方便的话,建议下个Demo。

 

2、通过VS中的Telerik新建一个Telerik项目。新建会有模板选项,还是比较方便的

3、添加菜单按钮

4、在后台添加事件处理即可。

private void ColumnsAndRowsTransformButton_OnClick(object sender, RoutedEventArgs e)
        {
            try
            {
                var workbook = viewModel.Workbook;
                var sheet = workbook.ActiveWorksheet;
                var ranges = sheet.ViewState.SelectionState.SelectedRanges;
                int insertRowsCount = 0;
                foreach (var range in ranges)
                {
                    if (range.IsSingleCell)
                    {
                        continue;
                    }
                    var firstRange=range.FromIndex;
                    //Foreach Rows
                    for (int i = 0; i < range.RowCount; i++)
                    {
                        int rowIndex = firstRange.RowIndex+i+ insertRowsCount;
                        int columnIndex = firstRange.ColumnIndex;

                        int currentRowAddRows = 0;
                        //赋值
                        for (int j = 1; j < range.ColumnCount; j++)
                        {
                            var cellValue =sheet.Cells[rowIndex, columnIndex + j].GetValue().Value;
                            if (string.IsNullOrEmpty(cellValue.RawValue))
                            {
                                continue;
                            }
                            sheet.Rows.Insert(rowIndex + 1+currentRowAddRows, 1);
                            
                            currentRowAddRows++;

                            sheet.Cells[rowIndex + j, columnIndex].SetValue(cellValue.RawValue);
                            sheet.Cells[rowIndex, columnIndex + j].SetValue("");
                        }
                        //本行单元格复制上行内容

                        int index = 0;
                        do
                        {
                            var upValue = sheet.Cells[rowIndex, index].GetValue().Value;
                            if (string.IsNullOrEmpty(upValue.RawValue) && index > 50)
                            {
                                break;
                            }

                            if (index != columnIndex)
                            {
                                for (int j = 0; j < currentRowAddRows; j++)
                                {
                                    sheet.Cells[rowIndex +1 + j, index].SetValue(upValue);
                                }
                            }
                            index++;
                        } while (true);

                        insertRowsCount += currentRowAddRows;
                    }
                        
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
View Code

这个Telerik控件还是比较方便的。

 

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须在文章页面给出原文连接,否则保留追究法律责任的权利。
目录
相关文章
|
Web App开发 C# Windows
WPF 制作电子相册浏览器
原文:WPF 制作电子相册浏览器    周末的时候,闲着无聊,做了一个电子相册浏览器。比较简单。界面如下: 主要部分代码如下: MainWindow.xaml ...
1003 0
|
4月前
|
C# 开发者 Windows
基于Material Design风格开源、易用、强大的WPF UI控件库
基于Material Design风格开源、易用、强大的WPF UI控件库
319 0
|
4月前
|
C#
浅谈WPF之装饰器实现控件锚点
使用过visio的都知道,在绘制流程图时,当选择或鼠标移动到控件时,都会在控件的四周出现锚点,以便于修改大小,移动位置,或连接线等,那此功能是如何实现的呢?在WPF开发中,想要在控件四周实现锚点,可以通过装饰器来实现,今天通过一个简单的小例子,简述如何在WPF开发中,应用装饰器,仅供学习分享使用,如有不足之处,还请指正。
117 1
|
C# Windows
WPF技术之RichTextBox控件
WPF RichTextBox是Windows Presentation Foundation (WPF)中提供的一个强大的文本编辑控件,它可以显示富文本格式的文本,支持多种文本处理操作。
533 0
|
1月前
|
开发框架 缓存 前端开发
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(11) -- 下拉列表的数据绑定以及自定义系统字典列表控件
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(11) -- 下拉列表的数据绑定以及自定义系统字典列表控件
|
1月前
|
C# 开发者 Windows
一款基于Fluent设计风格、现代化的WPF UI控件库
一款基于Fluent设计风格、现代化的WPF UI控件库
|
21天前
|
C# 前端开发 UED
WPF数据验证实战:内置控件与自定义规则,带你玩转前端数据验证,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用开发中,数据验证是确保输入正确性的关键环节。前端验证能及时发现错误,提升用户体验和程序可靠性。本文对比了几种常用的WPF数据验证方法,并通过示例展示了如何使用内置验证控件(如`TextBox`)及自定义验证规则实现有效验证。内置控件结合`Validation`类可快速实现简单验证;自定义规则则提供了更灵活的复杂逻辑支持。希望本文能帮助开发者更好地进行WPF数据验证。
38 0
|
21天前
|
C# UED 定位技术
WPF控件大全:初学者必读,掌握控件使用技巧,让你的应用程序更上一层楼!
【8月更文挑战第31天】在WPF应用程序开发中,控件是实现用户界面交互的关键元素。WPF提供了丰富的控件库,包括基础控件(如`Button`、`TextBox`)、布局控件(如`StackPanel`、`Grid`)、数据绑定控件(如`ListBox`、`DataGrid`)等。本文将介绍这些控件的基本分类及使用技巧,并通过示例代码展示如何在项目中应用。合理选择控件并利用布局控件和数据绑定功能,可以提升用户体验和程序性能。
38 0
|
1月前
|
C# Windows
WPF中如何使用HandyCotrol控件库
WPF中如何使用HandyCotrol控件库
85 1
|
1月前
|
开发框架 前端开发 JavaScript
WPF应用开发之控件动态内容展示
WPF应用开发之控件动态内容展示