【软件基础】Linq优化双重for循环、批量写入Excel以提升程序运行速度、常见代码优化方法

文章目录

  • 前言
  • 一、使用Linq优化双重for循环
  • 二、使用Office插件批量写入Excel
  • 三、常见代码优化方法
      • 1、字符串拼接
      • 2、使用 LINQ 查询
      • 3、频繁访问数据库
      • 4、频繁使用大对象图
      • 5、未使用索引进行查找
      • 6、频繁的装箱和拆箱操作
      • 7、使用递归导致堆栈溢出
      • 8、频繁的文件I/O操作
      • 9、未使用并行处理
  • 总结


前言

在软件开发过程中,性能优化是一个至关重要的环节。当处理大量数据时,传统的双重for循环和逐个写入Excel的方式可能会成为性能瓶颈。本文将介绍两种优化方法:使用Linq来替代双重for循环,以及使用Office插件的批量写入功能来提升数据写入Excel的效率。

一、使用Linq优化双重for循环

双重for循环在处理二维数组或列表时很常见,但如果数据量较大,这种循环方式可能会导致性能问题。Linq(Language Integrated Query)是C#提供的一种强大的查询功能,它允许我们以声明性方式查询和操作数据,而无需编写显式的循环代码。

以下是一个使用双重for循环的示例:

int[,] matrix = { {1, 2, 3}, {4, 5, 6}, {7, 8, 9} };  
List<int> results = new List<int>();  for (int i = 0; i < matrix.GetLength(0); i++)  
{  for (int j = 0; j < matrix.GetLength(1); j++)  {  if (matrix[i, j] % 2 == 0) // 假设我们找所有偶数  results.Add(matrix[i, j]);  }  
}

使用Linq优化后的代码:

int[,] matrix = { {1, 2, 3}, {4, 5, 6}, {7, 8, 9} };  
List<int> results = Enumerable.Range(0, matrix.GetLength(0))  .SelectMany(i => Enumerable.Range(0, matrix.GetLength(1)).Select(j => matrix[i, j]))  .Where(num => num % 2 == 0)  .ToList();

在上面的Linq示例中,我们使用Enumerable.Range来模拟二维数组的索引,然后使用SelectMany来“展平”二维结构,并通过Where筛选出偶数。最后,使用ToList将结果转换为列表。

二、使用Office插件批量写入Excel

当使用Office插件(如Microsoft.Office.Interop.Excel)将数据写入Excel时,逐个写入单元格的方式可能会导致性能下降。为了提高性能,我们可以使用批量写入的方式,即一次性将多个值写入一个范围。

以下是一个逐个写入单元格的示例:

Excel.Application excelApp = new Excel.Application();  
Excel.Workbook workbook = excelApp.Workbooks.Add();  
Excel.Worksheet worksheet = (Excel.Worksheet)workbook.Sheets[1];  for (int i = 1; i <= 1000; i++)  
{  worksheet.Cells[i, 1] = "数据" + i;  
}  workbook.SaveAs("C:\\temp\\Test.xlsx");  
workbook.Close();  
excelApp.Quit();

使用批量写入优化后的代码:

Excel.Application excelApp = new Excel.Application();  
Excel.Workbook workbook = excelApp.Workbooks.Add();  
Excel.Worksheet worksheet = (Excel.Worksheet)workbook.Sheets[1];  // 准备要写入的数据  
object[,] data = new object[1000, 1];  
for (int i = 0; i < 1000; i++)  
{  data[i, 0] = "数据" + (i + 1);  
}  // 批量写入数据  
Excel.Range range = worksheet.Range[worksheet.Cells[1, 1], worksheet.Cells[1000, 1]];  
range.Value2 = data;  workbook.SaveAs("C:\\temp\\Test_Batch.xlsx");  
workbook.Close();  
excelApp.Quit();

在上面的优化示例中,我们首先创建了一个二维对象数组data来存储要写入的数据。然后,我们定义了一个Excel范围range,它覆盖了我们要写入的单元格。最后,我们将整个data数组一次性写入该范围,从而避免了逐个写入单元格的开销。

三、常见代码优化方法

1、字符串拼接

string result = "";
for (int i = 0; i < 1000; i++)
{result += i.ToString();
}

优化:
使用 StringBuilder 类来优化字符串拼接。

StringBuilder sb = new StringBuilder();
for (int i = 0; i < 1000; i++)
{sb.Append(i);
}
string result = sb.ToString();

2、使用 LINQ 查询

var result = list.Where(x => x.Property == value).ToList();

优化
对于简单的过滤,使用 foreach 循环。

List<T> result = new List<T>();
foreach (var item in list)
{if (item.Property == value){result.Add(item);}
}

3、频繁访问数据库

foreach (var item in items)
{var data = dbContext.GetData(item.Id);// Process data
}

优化
尽可能减少对数据库的访问,可以考虑在循环外部一次性获取所有数据。

var itemIds = items.Select(i => i.Id).ToList();
var data = dbContext.GetDataForItems(itemIds);foreach (var item in items)
{var itemData = data.FirstOrDefault(d => d.Id == item.Id);// Process itemData
}

4、频繁使用大对象图

public class Person
{public string Name { get; set; }public List<Address> Addresses { get; set; }// Other properties
}List<Person> people = GetPeopleFromDatabase();
foreach (var person in people)
{ProcessPerson(person);
}

优化
尽量避免加载完整的对象图,可以使用延迟加载或仅加载必要的属性。

List<Person> people = GetPeopleFromDatabase();
foreach (var person in people)
{// Load addresses only when neededperson.Addresses = GetAddressesForPerson(person.Id);ProcessPerson(person);
}

5、未使用索引进行查找

var item = list.FirstOrDefault(x => x.Id == searchId);

优化
如果列表较大,应该使用索引进行快速查找。

var dictionary = list.ToDictionary(x => x.Id);
var item = dictionary.ContainsKey(searchId) ? dictionary[searchId] : null;

6、频繁的装箱和拆箱操作

int sum = 0;
for (int i = 0; i < 1000; i++)
{sum += i;object boxedSum = sum; // Boxing operationint unboxedSum = (int)boxedSum; // Unboxing operation
}

优化
避免不必要的装箱和拆箱操作,尽可能直接使用值类型。

int sum = 0;
for (int i = 0; i < 1000; i++)
{sum += i;
}

7、使用递归导致堆栈溢出

public int Factorial(int n)
{if (n == 0){return 1;}else{return n * Factorial(n - 1); // Recursive call}
}

优化
避免深度递归调用,可以改为使用迭代或尾递归优化。

public int Factorial(int n)
{int result = 1;for (int i = 1; i <= n; i++){result *= i;}return result;
}

8、频繁的文件I/O操作

foreach (var file in files)
{string content = File.ReadAllText(file);// Process file content
}

优化
减少文件I/O操作次数,尽可能合并读写操作。

List<string> contents = new List<string>();
foreach (var file in files)
{contents.Add(File.ReadAllText(file));
}
// Process file contents

9、未使用并行处理

List<int> numbers = Enumerable.Range(1, 1000000).ToList();
List<int> squaredNumbers = new List<int>();
foreach (var num in numbers)
{squaredNumbers.Add(num * num);
}

优化
使用并行处理可以提高处理速度。

List<int> numbers = Enumerable.Range(1, 1000000).ToList();
List<int> squaredNumbers = new List<int>();
Parallel.ForEach(numbers, num =>
{squaredNumbers.Add(num * num);
});

总结

通过这两种优化方法,我们可以显著提高程序处理大量数据时的性能。但是,请注意,在使用Linq和Office插件时,还需要考虑其他性能因素,如内存使用和垃圾回收等。

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

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

相关文章

Python 学习 第二册 对第一册的一些补充

-----用教授的方法学习 1.一些常见函数 函 数 描 述 abs(number) 返回指定数的绝对值 bytes(string, encoding[, errors]) 对指定的字符串进行编码&#xff0c;并以指定的方式处理错误 cmath.sqrt(number) 返回平方根&#xff1b;可用于负数 float(object) 将字符…

k8s-kubernetes常用命令,服务部署,可视化控制台安装及token的生成

上一篇文章介绍了怎么安装kubernetes,现在我们来学习下kubernetes的常用命令 我们直接通过部署可视化控制台kubernetes-dashboard来顺便学习下kubernetes的常用命令及服务的部署 kubernetes dashboard部署 执行下面的命令下载及安装 kubernetes dashboard kubectl apply -f…

数据分析------统计学知识点(五)

回归算法 想象一下&#xff0c;你和朋友在讨论:大学生活中&#xff0c;每天学习的时间是否真的能影响期末成绩?这个问题看似简单&#xff0c;实则包含了一个潜在的关系:学习时间与成绩之间的联系。我们想要知道&#xff0c;增加学习时间是否会提高成绩&#xff0c;以及这种提…

MYSQL 索引下推 45讲

刘老师群里,看到一位小友 问<MYSQL 45讲>林晓斌的回答 大意是一个组合索引 (a,b,c) 条件 a > 5 and a <10 and b123, 这样的情况下是如何? 林老师给的回答是 A>5 ,然后下推B123 小友 问 "为什么不是先 进行范围查询,然后在索引下推 b123?" 然后就…

热门开源大模型项目推荐

一&#xff1a;开源大模型热门项目推荐 NNI&#xff1a;由微软发布的开源AutoML工具包&#xff0c;支持神经网络超参数调整。最新版本对机器学习生命周期的各个环节做了全面支持&#xff0c;包括特征工程、神经网络架构搜索(NAS)、超参调优和模型压缩。适用于各种机器学习项目&…

C++240613

自由发挥登录窗口的应用场景&#xff0c;实现一个登录窗口界面 要求&#xff1a;每行代码都有注释 #include "my_widget.h"My_Widget::My_Widget(QWidget *parent): QWidget(parent) {//设置窗口的标题this->setWindowTitle("真爱生命&#xff0c;远离赌博&…

2024大交通场景空间策展洞察报告

来源&#xff1a;邻汇吧&万一商管 近期历史回顾&#xff1a; 2024国内工商业储能市场研究报告.pdf 2023幸福企业白皮书.pdf 2024年欧亚地区移动经济报告.pdf 内容供应链变革 2023人工智能与首席营销官&#xff08;CMO&#xff09; AI科技对PC产业的影响.pdf 金融业数据应用…

智能合约漏洞类型

Are We There Yet? Unraveling the State-of-the-Art Smart Contract Fuzzers | Proceedings of the IEEE/ACM 46th International Conference on Software Engineering

PySide6实现pdf转化为word和长图片

目录 一:实现思路 二:实现过程 三:完整代码和实现 一:实现思路 最近在使用wps,发现wps中使用pdf转化为长图片还需要收费,这么不地道。就想自己能不能用程序实现这种功能的。还好python在自动化办公领域比较强悍,对文档操作也是得心应手。因此记录下用python实现pdf转…

Java求职季 必备知识脑图 收藏起来 !!!

Java初中级知识脑图 面试超实用 1.Git 下载链接 导图下载地址 &#xff1a; https://mm.edrawsoft.cn/mobile-share/index.html?uuid31d00742157057-src&share_type1 2.JUC 下载链接 https://mm.edrawsoft.cn/mobile-share/index.html?uuid6c0be457444921-src&s…

计算机网络 —— 应用层(DNS域名系统)

计算机网络 —— 应用层&#xff08;DNS域名系统&#xff09; 什么是DNS域名的层次结构域名分类 域名服务器的分类域名解析方式递归查询&#xff08;Recursive Query&#xff09;迭代查询&#xff08;Iterative Query&#xff09;域名的高速缓存 我们今天来看DNS域名系统 什么…

批量文件重命名技巧:轻松替换删除文件夹名中的字母,实现高效文件管理新境界

在数字化时代&#xff0c;我们每天都会面对大量的文件和文件夹。无论是工作文档、学习资料还是个人收藏&#xff0c;文件命名的规范性都显得尤为重要。然而&#xff0c;手动一个一个去修改文件名&#xff0c;不仅耗时耗力&#xff0c;还容易出错。那么&#xff0c;有没有一种方…

SAP ABAP 之面向对象OO

文章目录 前言一、类的理解二、如何创建ABAP类 a.类的定义与构成 b.类的访问区域 c.特殊方法 d.类的继承 三、类中参数的使用 a.IMPORTING / EXPORTING b.CHANGING c.RETURNING d.EX…

【Jmeter】插件详解:PerfMon Metrics Collector 服务器性能监控插件

目录 一、前言 二、PerfMon Metrics Collector 插件详解 (1)插件简介 (2)功能介绍 (3)应用场景 (4)使用指南 ① 环境准备 ② 服务端插件配置 ③ 监听器配置 ④ 图表设置 ⑤ 非 GUI 模式 三、ServerAgent 下载 四、ServerAgent 安装 (1)安装 (…

在python中指定pytorch训练时使用多块或某块GPU的方法

1. 引入 PyTorch是一个流行的深度学习框架&#xff0c;它提供了方便的API&#xff0c;使得在GPU上进行模型训练变得简单。 然而&#xff0c;有时我们可能需要指定使用多个GPU或者特定的GPU来进行训练&#xff0c;以满足不同的需求。 之所以在python中指定GPU&#xff0c;而不是…

水库枢纽乙级设计资质下的团队构建

1. 技术负责人与核心团队 技术负责人&#xff1a;需具备高级专业技术职称&#xff0c;且在水利枢纽设计领域有丰富的实践经验&#xff0c;能够指导解决复杂技术难题。核心设计团队&#xff1a;包括但不限于水工结构、水文水资源、地质勘察、电气自动化、环境保护等专业领域的工…

PHP杂货铺家庭在线记账理财管理系统源码

家庭在线记帐理财系统&#xff0c;让你对自己的开支了如指掌&#xff0c;图形化界面操作更简单&#xff0c;非常适合家庭理财、记账&#xff0c;系统界面简洁优美&#xff0c;操作直观简单&#xff0c;非常容易上手。 安装说明&#xff1a; 1、上传到网站根目录 2、用phpMyad…

leetcode695 岛屿的最大面积

题目 给你一个大小为 m x n 的二进制矩阵 grid 。 岛屿 是由一些相邻的 1 (代表土地) 构成的组合&#xff0c;这里的「相邻」要求两个 1 必须在 水平或者竖直的四个方向上 相邻。你可以假设 grid 的四个边缘都被 0&#xff08;代表水&#xff09;包围着。 岛屿的面积是岛上值…

13. FastLED 示例3则

Best of FastLED Discussions 1. Fire2012&#xff1a; FastLED 火灾模拟器 // Fire2012: a basic fire simulation for a one-dimensional string of LEDs // Mark Kriegsman, July 2012. // // Compiled size for Arduino/AVR is about 3,968 bytes.#include <FastLED.h…

基于springboot实现入校申报审批系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现入校申报审批系统演示 摘要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装入校申报审批系统软…