【python VS vba(系列2)】 python和vba读写EXCEL文件的方式比较 (建设ing)

目录

[1 用VBA读写EXCEL文件](#1 用VBA读写EXCEL文件)

[1.1 用VBA读写,本工作簿workbook里的特定sheet的特定内容](#1.1 用VBA读写,本工作簿workbook里的特定sheet的特定内容)

[1.1.1 EXCEL表内内容访问](#1.1.1 EXCEL表内内容访问)

[1.1.2 注意点](#1.1.2 注意点)

[1.1.3 代码](#1.1.3 代码)

[1.2 用VBA读写本工作簿workbook里的所有sheet的内容](#1.2 用VBA读写本工作簿workbook里的所有sheet的内容)

[1.2.1 麻烦之处](#1.2.1 麻烦之处)

[1.2.2 方法,如何指定EXCEL里的内容范围](#1.2.2 方法,如何指定EXCEL里的内容范围)

[1.2.3 写入内容](#1.2.3 写入内容)

[1.3 尝试用VBA处理非本workbook,且未打开的情况](#1.3 尝试用VBA处理非本workbook,且未打开的情况)

[2 用python 读写EXCEL文件](#2 用python 读写EXCEL文件)


1 用VBA读写EXCEL文件

1.1 用VBA读写,本工作簿workbook里的特定sheet的特定内容

  • VBA对单个sheet处理
  • 特殊点:
  1. 处理本EXCEL文件,因为开着VBE,VBA属于本文件,所以本EXCEL表比然是打开的
  2. 对应语法用的也是 thisworkbook.worksheets() ,若不指定缺省也会如此默认

1.1.1 EXCEL表内内容访问

  • 具体到内部,因为EXCEL天生是表格,是数组,是2维数组等
  • 需要使用下面这些对象的层级
  1. sheet.cells()
  2. sheet.range()
  3. sheet.rows()
  4. 。。。

1.1.2 注意点

  • 注意用于保存workbook, worksheet的变量
  1. 必须先定义为对象
  2. 且用set赋值
  • 比如
  • Dim path1 As Object (或者worksheet)
  • Set path1 = ThisWorkbook.Worksheets("now")

1.1.3 代码

vbscript 复制代码
'VBA对单个sheet处理
'特殊点:处理本EXCEL文件,因为开着VBE,VBA属于本文件,所以本EXCEL表比然是打开的
Sub print2001()

    Dim path1 As Object
    Set path1 = ThisWorkbook.Worksheets("now")
    
    '读指定sheet里特定内容
    Debug.Print path1.Cells(1, 1)

    '往wb的指定sheet写入内容
    '查下path1当前最大行
    maxr = path1.Cells(9999, 1).End(xlUp).Row
    path1.Cells(maxr + 1, 1) = 100
    path1.Cells(maxr + 1, 2) = 101
    path1.Cells(maxr + 1, 3) = 102
    path1.Cells(maxr + 1, 4) = 103

End Sub

1.2 用VBA读写本工作簿workbook里的所有sheet的内容

  • 目标是遍历这个,整个thisworkbook里面的内容
  • '注意VBA里数组语法的 1 to 4 和1,4完全不同,后者是2维数组

1.2.1 麻烦之处

  • '处理EXCEL的内容会比一般文件麻烦,因为EXCEL天生是表格,是数组,是2维数组等
  • 'VBA处理一个wb里的多个sheet处理,同样使用循环
  1. 注意正确的是 for sheet in workbook.worksheets
  2. 注意是 for sheet in workbook.worksheet 或 for sheet in workbook是错误的

1.2.2 方法,如何指定EXCEL里的内容范围

  • 1 指定要读写的范围边界,写入数组,然后操作数组
  • 2 使用 sheet.usedrange() 作为数组的数据源

1.2.3 写入内容

  • 遍历 sheet,然后写入即可
vbscript 复制代码
'注意VBA里数组的1to4 和1,4完全不同,后者是2维数组
'VBA处理一个wb里的多个sheet处理
Sub print2002()

    Dim path1 As Object
    Dim wb As Object
    Dim sht As Object

    For Each sht In ThisWorkbook.Worksheets
        Debug.Print "sheetName=" & sht.Name
        
        maxr = sht.Cells(9999, 1).End(xlUp).Row
        maxl = sht.Cells(1, 9999).End(xlToLeft).Column
        Debug.Print "现有内容的最大行数=" & maxr
        Debug.Print "现有内容的最大列数=" & maxl
        
        '因为表很大,数据散布在全表的不同格子里,尝查找限定范围内的内容
        '显示指定区域的内容
        arr1 = sht.Range("a1:d10")
        For i = LBound(arr1, 1) To UBound(arr1, 1)
            For j = LBound(arr1, 2) To UBound(arr1, 2)
                Debug.Print arr1(i, j),
            Next
            Debug.Print
        Next
        
        '显示表里用过的内容
        arr2 = sht.UsedRange
        For i = LBound(arr2, 1) To UBound(arr2, 1)
            For j = LBound(arr2, 2) To UBound(arr2, 2)
                Debug.Print arr2(i, j),
            Next
            Debug.Print
        Next
     Next
    
    '这里写入
    '往wb的指定sheet写入内容,还是先只追加1行
    '查下path1当前最大行
    For Each sht In ThisWorkbook.Worksheets
        For k = 1 To 4
            sht.Cells(maxr + 1, k) = 99 * k
        Next
    Next

End Sub

1.3 尝试用VBA处理非本workbook,且未打开的情况

2 用python 读写EXCEL文件

需要加载专门的模块---也就是前人造好的轮子,比如这2个:

相关推荐
曹牧2 天前
Excel:筛选两列中不匹配项
excel
それども2 天前
Excel文件解析 - 什么是SAX和DOM
java·excel
それども2 天前
Excel文件解析 - SAX和DOM方式的区别
java·前端·excel
それども2 天前
Excel文件解析 - SAX startRow cell endRow 执行顺序
java·前端·excel
梦因you而美2 天前
Python win32com操作Excel:彻底禁用链接更新及各类弹窗(实测有效)
python·excel·win32com·禁用链接更新·excel弹框
それども2 天前
Excel文件解析 - SAX startRow cell endRow 执行时机
java·excel
HWL56792 天前
在网页中实现WebM格式视频自动循环播放
前端·css·html·excel·音视频
开开心心就好3 天前
图片校正漂白工具永久免费,矫正实时预览
网络·人工智能·windows·计算机视觉·计算机外设·电脑·excel
开开心心_Every3 天前
音频视频转文字工具,离线语音识别免费
人工智能·游戏·微信·pdf·excel·语音识别·memcache
开开心心_Every3 天前
电脑网速加速工具,无线有线叠加网络
网络·游戏·微信·pdf·电脑·excel·语音识别