找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 16706|回复: 10

[问题求助] powershell 操作 MiniExcel

[复制链接]
发表于 2022-9-21 12:09:23 | 显示全部楼层 |阅读模式
本帖最后由 5i365 于 2022-9-21 12:14 编辑

刚发现一个dll只有162k的开源Excel库, 描述中对比了N多组件, 占用资源极小, 地址如下:

https://www.nuget.org/packages/MiniExcel


求大侠写一个等效于如下EPPlus.dll操作excel的代码, 找到的图片中的代码


Add-Type -Path ".\EPPlus.dll"
$ex = New-Object OfficeOpenXml.ExcelPackage(".\a.xlsx")
$ex.Workbook.Worksheets[1].Cells["A1"].Value





发表于 2022-9-21 16:29:50 | 显示全部楼层
  1. Add-Type -Path .\MiniExcel.dll -ErrorAction Stop
  2. $excelFile = '.\3.xlsx'
  3. :label1
  4. foreach ($shtName in [MiniExcelLibs.MiniExcel]::GetSheetNames($excelFile)) {
  5.   foreach ($dicRow in [MiniExcelLibs.MiniExcel]::Query($excelFile, $false, $shtName, 'xlsx', 'A1')) {
  6.     foreach ($kvp in $dicRow) {
  7.       $kvp.Value
  8.       break label1
  9.     }
  10.   }
  11. }
复制代码
 楼主| 发表于 2022-9-21 17:18:41 | 显示全部楼层
回复 2# flashercs


  感谢大侠,
powershell 不能用标签吧? :label1

感觉MiniExcel好绕, 不能像ep三行代码就搞定吗?
发表于 2022-9-21 17:42:34 | 显示全部楼层
本帖最后由 flashercs 于 2022-9-21 17:49 编辑

回复 3# 5i365


    这样效率最高;MiniExcel 返回的一堆单元格,而不支持单个单元格数据读取; 设计如此.
遍历所有单元格:
  1. Add-Type -Path .\MiniExcel.dll -ErrorAction Stop
  2. $excelFile = '.\3.xlsx'
  3. :label1
  4. foreach ($shtName in [MiniExcelLibs.MiniExcel]::GetSheetNames($excelFile)) {
  5.   foreach ($dicRow in [MiniExcelLibs.MiniExcel]::Query($excelFile, $false, $shtName, 'xlsx', 'A1')) {
  6.     foreach ($kvp in $dicRow) {
  7.       $kvp.ToString()
  8.      
  9.     }
  10.   }
  11. }
复制代码
 楼主| 发表于 2022-9-21 18:01:21 | 显示全部楼层
回复 4# flashercs


明白了, 多谢大侠指点
 楼主| 发表于 2022-9-24 16:55:49 | 显示全部楼层
回复 4# flashercs

大侠遇到一个问题请教下面的代码总是报错
Could not load file or assembly 'System.Memory, Version=4.0.1.2
用VS就能执行成功

Add-Type -Path ".\MiniExcel.dll"
$csv = "$HOME\Desktop\AA.csv"
[MiniExcelLibs.MiniExcel]::ConvertCsvToXlsx($csv, '.\AB.xlsx')
发表于 2022-9-24 22:11:14 | 显示全部楼层
回复 6# 5i365
  1. Add-Type -Path .\*.dll
复制代码
应该加载所有的dll
 楼主| 发表于 2022-9-25 05:10:36 | 显示全部楼层
回复 7# flashercs

C#和PS加载的都只有一个Dll文件
下面的xlsx转csv能成功, 反过来就不行了, 怪了

Add-Type -Path ".\MiniExcel.dll"
$xlsx = "$HOME\Desktop\AA.xlsx"
[MiniExcelLibs.MiniExcel]::ConvertXlsxToCsv($xlsx, '.\AB.csv')
发表于 2022-9-25 12:38:41 | 显示全部楼层
回复 8# 5i365


链接:https://pan.baidu.com/s/1gLyMAjghKzyX9dqkMpuh-g
提取码:ils1
 楼主| 发表于 2022-9-25 13:22:28 | 显示全部楼层
回复 9# flashercs

感谢大谢帮忙, 这回行了, system开头的dll不是系统本来就有吗?
本来考虑这个组件只有160k很小, 如果还要额外加几个dll就不方便了
 楼主| 发表于 2022-9-25 13:24:04 | 显示全部楼层
回复 9# flashercs

我感觉应该系统中的也应该能用, 我用linqpad测试C#代码, 没有用额外的dll也可以执行
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 04:28 , Processed in 0.011640 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表