1. vba字符串变量
vba的函数名可以是英文字符,数字,中文字符等,但不可以使用变量。
2. vba字符串变量超长
提供一个消息框手动输入的办法。
先定义一个变量:
dim inputvalue as string
然后变量赋值:
inputvalue = inputbox("请输入数值")
然后使用msgbox弹出消息框用来输入:
msgbox inputvalue
这样就有消息提供输入。
3. vba字符串变量值做语句
字符串类型,符号:String
字符串是用于保存文本数据的,字符串内容应放置于双引号内。字符长度4字节。
二 字节型,符号:Byte
字节型字符的长度是1个字节。
三 布尔型,符号Boolean
布尔型数据用于表示逻辑值:真、假 。其中“真”为True,“假”为False。布尔值数据常用于条件判断语句。布尔型字符长度是2个字节。
应当注意的是,当其它数据类型转换为布尔值时,0会转成False,其它值则变成True。当把布尔值转换成其他数据类型时,False会转换为0,True则是-1。
注意:和EXCEL的不同点:VBA中当把布尔值转换成其他数据类型时,False会转换为0,True则是-1。
四 数字的类型 VBA中用于表示数字的数据类型有4种:
整型 Integer,占用两个字节;长整型 Long,占用4个字节;单精度浮点型 Single,占用4个字节;双精度浮点型 Double,占用8个字节.
1. 整型及长整型用于表示整数,单精度与双精度浮点型都用于表示小数。
2 整型与长整型的区别在于两者所能表示的数值范围不同:
3 整型数据能表示的数据范围:-32768 ~ 32767
4 长整型数据能表示的数据范围:-2147483648 ~ 2147483647
5 单精度浮点数与双精度浮点数除了在数值范围不同之外,两者所能表示的数据精度(即小数点后多少位)也是不同的
6 单精度浮点型能表示的数据范围:
在表示负数时: -3.402823E38 ~ -1.401298E-45
在表示正数时: 1.401298E-45 ~ 3.402823E38
7 双精度浮点型能表示的数据范围:
在表示负数时: -1.79769313486231E308 ~ -4.94065645841247E-324
在表示正数时: 4.94065645841247E-324 ~ 1.79769313486231E308
8 单精度浮点型其精度是6,即只能保存小数点后最多6位的数据;如果超出以上长度,则超出部分会被去掉,并且会自动四舍五入。
9 双精度浮点型其精度是14,即只能保存小数点后最多14位的数据。如果超出以上长度,则超出部分会被去掉,并且会自动四舍五入。
上述各类型的数据在使用时要遵守的一个原则就是:够用就好。而不是越大越好。
五. 日
4. vba 字符串
VBA窗体,制作二级联动下拉菜单,进行快速录入,只需一个窗体,两个标签,两个组合框,一个命令按钮和几行代码即可。
Sub Word使用正则表达式批量设置标题样式()
'创建正则表达式对象
Dim objRegExp As Object
'创建word对象
Dim docDocument As Document
Dim i As Integer
Dim k As String, nPt As String, sty As String
nPt = InputBox("请输入需要匹配的正则表达式")
Set objRegExp = CreateObject("vbscript.regexp")
With objRegExp
'正则表达式匹配文本类型
.Pattern = nPt
'设置仅匹配第一个或是匹配所有符合条件的内容
.Global = True
.MultiLine = False
.IgnoreCase = False
End With
sty = InputBox("请输入样式名称")
Set docDocument = ActiveDocument
For i = 1 To docDocument.Paragraphs.Count
k = docDocument.Paragraphs(i).Range.Text
If objRegExp.test(k) Then
docDocument.Paragraphs(i).Range.Select
With Selection
'如果匹配到符合条件的标题,则将其样式设置为sty(注:sty为Word中的样式名称,需在程序运行前预先定义好)
.Style = ActiveDocument.Styles(sty)
End With
End If
Next
End Sub
5. vba字符串变数值
worksheets("B").cells.NumberFormatLocal = "0.00_ " 以上将B表格式改为2位小数
6. vba字符串变量怎样声明
VBA中给变量赋值如果未设置对象变量,使用set和不使用set的区别:
'给普通变量赋值使用LET ,只是LET 可以省略。
'给对象变量赋值使用SET,SET 不能省略。例如ADODB.RecordSet等对象。
VBA中变量用dim定义和不用dim定义而直接使用有何区别?'DIM 语句 的作用似乎声明变量并分配存储空间。'如果不指定数据类型或对象类型,也就是不用DIM定义,且在模块中没有 Deftype 语句,'则该变量按缺省设置是 Variant 类型。
7. vba字符串变量赋值
VBA对子程序和函数有如下的命名规则:
1)第一个字符必须是字母。
2)名字中可以包含字母、数字和下划线。
3)名字中不能包含空格、句号、惊叹号,也不能包含字符@、&、$和#。
4)名字中最多包含255个字符。
2/3
变量的类型
变量用于保存过程数据。下面是VBA中使用的变量类型。变量名的命名规则与过程名相同。变量的定义使用Dim 变量名 as 数据类型
3/3
变量的声明
下面将创建一个过程,其功能是提示用户输入名字,接着在消息框中显示出来。
Public Sub KnowYourName()
Dims Name As String
sName = InputBox("Enteryourname:")
MsgBox "Hi"&sName
End Sub
其中Name是一个字符串变量,在Dim语句中不必提供数据类型。如果没有提供数据类型,变量将被指定为VBA中默认的数据类型Variant 。如果不定义数据类型会占用空间与提高运行时间。
Dim iNumberOfStudents as Integer
Dim dTestDate as Date
'The following line creates a variable length string
Dim sLastName as String
'The next line creates a 2char. Fixed length string
Dim sState as String*2
可以通过以单引号开头加注释
8. vba字符串变量拼接
看到Excel多表合并,其实常见的有2种场景
场景一:多个Excel文件需要合并为1个Excel文件(多个工作簿合并为1个工作簿)
场景二:1个Excel文件种有多个工作表,需要合并为1个工作表
首先来看下,场景一(多个Excel文件合并为1个文件),都有哪些方法可以实现?
场景描述:如图所示,在文件夹中,有4个Excel文件,每个Excel文件的数据格式都一致,需要把4个Excel文件合并到1个Excel文件中。
每个工作簿中的内容格式都一样,为了区分,我把工作簿1中的 位置 数据,标为了“工作簿1”;工作簿2中的数据标为了“工作簿2”...以此类推。
下面雷哥推荐几种方法来实现多个Excel文件合并为1个文件
方法1:PowerQuery
Step1:单击 【数据】- 【新建查询】 - 【从文件】- 【从文件夹】
Step2:单击 【浏览】,选择文件夹路径
Step3:选择【合并并加载】
最终的效果如图所下图所示。自动增加了
Source.Name
数据列,可以很方便看到数据来自于哪个工作簿
方法2:使用CMD命令,1s搞定合并
Step1:需要把文件格式修改为 csv文件格式。打开文件,另存为csv文件即可
Step2:在文件所在路径,按【shift】+右键,点击【此处打开命令窗口】,输入
copy *.csv out.csv, 即把该路径下所有的csv文件合并到out.csv文件中。
下面来看下,场景二(多个Excel工作表合并为1个Excel工作簿),都有哪些方法可以实现?
场景描述:如图所示,1个excel文件中,有多个工作表,需要合并到1个工作表中。
方法1:PowerQuery法
Step1:单击 【数据】- 【新建查询】 - 【从工作簿】
Step2:选择需要合并的工作表
Step3:在追加查询中,单击【将查询追加为新查询】
Step4:选择所需的工作表
Step5:单击关闭并上载
最终的效果如图所示
方法2:使用宏
Step1:按【Alt】+【F11】
Step2:输入代码,并单击三角形图标运行
Application.ScreenUpdating = False For j = 1 To Sheets.Count If Sheets(j).Name <> ActiveSheet.Name Then X = Range("A60000).End(xlUp).Row + 1 Sheets(j).UsedRange.Copy Cells(X, 1) End If Next Range("B1").Select Application.ScreenUpdating = True MsgBox "小主,数据合并结束啦!", vbInformation, "提示" End Sub
运行效果如下图所示,后续我们删去多余的标题行即可~
方法3:插件法 - 最简单
Step1:使用【方方格子】插件,单击【合并工作表】
Step2:选择汇总区域后,单击确定
最终的效果如下
还是插件最简单,分分钟搞定哈~
雷哥:自媒体【雷哥office】创始人,《竞争力:玩转职场Excel,从此不加班》作者,微软Excel专家认证,office培训师,职场老司机,分享职场经验 / 办公技能 / 提高职场效率!
- 相关评论
- 我要评论
-