ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: 小花鹿

[讨论] 小花鹿学习VBA记录

  [复制链接]

TA的精华主题

TA的得分主题

发表于 2013-4-10 16:34 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
包括进度条控制的代码如下:
  1. Private Sub Workbook_Open()

  2.     Set FS = CreateObject("Scripting.FileSystemObject")
  3.     Set f = FS.OpenTextFile(ThisWorkbook.Path & "\Dir.bat", 2, TristateFalse)
  4.    
  5.     Pth = ThisWorkbook.Path
  6.     f.Writeline "Dir """ & Pth & """\*.xl*/s>""" & Pth & "\DosRslt.xls"""
  7.     f.Writeline "Copy """ & Pth & "\DosRslt.xls"" """ & Pth & "\DirRslt.xls"""
  8.     f.Writeline "Exit"
  9.     f.Close
  10.    
  11.     If Dir(Pth & "\DirRslt.xls") <> "" Then Kill (Pth & "\DirRslt.xls")
  12.     Shell Pth & "\Dir.bat", vbHide '在Excel中调用Dos批处理文件执行Dos的Dir命令
  13.    
  14.     k = 1000 'Max Count
  15.     UserForm1.Show 0
  16.     UserForm1.ProgressBar1.Max = k
  17.     For h = 1 To k
  18.         [a1] = h
  19.         f = Format(h / k, "0.00%")
  20.         UserForm1.Caption = "Dos Dir >>>> Please wait ......" & f
  21.         UserForm1.ProgressBar1.Value = h
  22.         
  23.         If Dir(Pth & "\DirRslt.xls") = "" Then
  24.             If h = k Then h = 500
  25.         Else
  26.             h = k
  27.         End If
  28.     Next
  29.     Kill (Pth & "\DirRslt.xls")
  30.     UserForm1.Caption = "Dos Dir 已全部完成 !"
  31.     Beep
  32.    
  33.     Workbooks.Open Filename:=ThisWorkbook.Path & "\DosRslt.xls"
  34.    
  35.     ThisWorkbook.Close False
  36. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-4-10 17:59 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
递归简单模型:
Option Explicit
Dim ar(), n&
Sub main()
Dim num&
n = 0
num = 60
Call recursive(num)
MsgBox num & "的质因数是:" & Join(ar)
End Sub
Sub recursive(num)
If num = 1 Then Exit Sub
Dim i&
For i = 2 To num
    If num / i = Int(num / i) Then Exit For
Next i
n = n + 1
ReDim Preserve ar(1 To n)
ar(n) = i
Call recursive(num / i)
End Sub
参考资料:http://club.excelhome.net/thread-891872-5-1.html

点评

不错啊。递归学的很快哦。很有成就感吧……  发表于 2013-4-10 19:52

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-4-11 11:07 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 小花鹿 于 2013-4-16 11:29 编辑

文章来自本站,放在这里是为了查找方便。


VBA FSO对象模型详解.rar (13.77 KB, 下载次数: 58)

FSO 读写文本文件 几种情形.rar (3.74 KB, 下载次数: 51)

Excel-VBA 文件处理.rar (10.36 KB, 下载次数: 71)

VBA使用FileSystemObject读取或写入文本文档.rar (8.21 KB, 下载次数: 58)


TA的精华主题

TA的得分主题

发表于 2013-4-11 11:46 | 显示全部楼层
查找文件夹中指定类型文件的程序更新:

1. 可以自己选择文件夹
2. 可以指定文件类型(指定后缀)如: xl=xl*(含xls、xla、xlsm、xlsx)

GetFileList.zip

13.43 KB, 下载次数: 86

点评

经测试,选择磁盘时出现错误。  发表于 2013-4-11 12:26

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2013-4-11 11:49 | 显示全部楼层
Dos版Dir方法也做了同步更新。

DosDir.zip

7.63 KB, 下载次数: 42

TA的精华主题

TA的得分主题

发表于 2013-4-11 19:08 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
香川群子 发表于 2013-4-11 11:46
查找文件夹中指定类型文件的程序更新:

1. 可以自己选择文件夹

哪里有问题? 我测试都是正常的。

不过是整个硬盘查找时间会长一点……

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-4-12 13:33 | 显示全部楼层
文本文件转xls:
Sub test()
Dim thispath, txtfile, linedata, linear, r&, i&
thispath = ThisWorkbook.Path & "\"
txtfile = Dir(thispath & "客户提供数据信息\*.txt")
Do While txtfile <> ""
    Open thispath & "客户提供数据信息\" & txtfile For Input As #1
    Workbooks.Add
    Do Until EOF(1)
        r = r + 1
        Line Input #1, linedata
        linear = Split(linedata, vbTab)
        For i = 0 To UBound(linear)
            Cells(r, i + 1) = "'" & linear(i)
        Next i
    Loop
    Close #1
    Application.DisplayAlerts = False
    ActiveWorkbook.SaveAs thispath & "导出处理后数据\" & Split(txtfile, ".")(0) & ".xls"
    Application.DisplayAlerts = True
    ActiveWindow.Close
    r = 0
    txtfile = Dir
Loop
End Sub

txt转xls.rar

196.3 KB, 下载次数: 57

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-4-19 15:07 | 显示全部楼层
以下文章来自本站,放在这里是为了查找方便。

Format函数
VBA 的 Format 函数与工作表函数 TEXT 用法基本相同,但功能更加强大,许多格式只能用于VBA 的 Format 函数,而不能用于工作表函数 TEXT ,以下是本人归纳的几点用法,希望对学习VBA有所裨益。

Format ( 值 , 格式(可选参数 ) )

一、数字格式:

1、General Number:普通数字,可以用来去掉千位分隔号和无效 0 。
如:Format("1,234,567.80", "General Number")="1234567.8"

2、Currency:货币类型,可添加千位分隔号和货币符号,保留两位小数点。
如:Format(1234567, "Currency")="1,234,567.00"

3、Fixed:格式为带两位小数的数字。
如:Format("123456", "Fixed")=123456.00

4、Standard:标准,即带千位分隔号和两位小数。
如:Format("123456", "Standard")=123,456.00

5、Percent:带两位小数点的百分数。
如:Format("123456", "Percent")=12345600.00

6、Scientific:科学记数法。
如:Format("1234567", "Scientific")=1.23E+06

7、Yes/No:当数值为非 0 数字时返回 Yes ,否则返回 No 。
"如:Format(-3.14, "Yes/No")="Yes"
    Format(0, "Yes/No")="No"

8、True/False:当数值为非 0 数字时返回 True ,否则返回 False 。
与第7点类似,这里不再举例。

9、On/Off:当数值为非 0 数字时返回 On ,否则返回 Off 。
与第7点类似,这里不再举例。
10、""或省略:返回原值,但去除了小数点前后的无效 0 。
如:Format("0.1030", "")=".103"

11、0:占位格式化,不足位时补足 0 。
"如:Format(123, "0000")="0123"
    Format$(12.3, "0.00")="12.30"

12、#:占位格式化,不足位时不补足 0 。
如:Format(123, "####")=123

13、%:转化为百分数,一个%代表乘以 100 。
如:Format(1.23, "0.00%")=123.00%
    Format(1.23, "0.00%%")=12300.00%%

14、\:强制显示某字符。
如:Format$(12.34, "\R\M\B .00")="RMB 12.34"

15、;(分号):分段显示不同格式
比如要把正数显示为“正”,负数显示为“负”,0显示为“零”,参数为"正;负;零"
如:Format$(123, "正;负;零")="正"
第1段为正数格式,第2段为负数格式,第3段为0格式。

二、日期和时间格式:

1、固定格式参数
General Date:基本类型
如:Format("2010-5-1 9:8:5", "General Date")="2010/5/1 9:08:05"

Long Date:操作系统定义的长日期
如:Format("2010-5-1 9:8:5", "Long Date")=2010年5月1日

Medium Date:中日期
如:Format("2010-5-1 9:8:5", "Medium Date")=10-05-01

Short Date:操作系统定义的短日期
如:Format("2010-5-1 9:8:5", "Short Date")=2010-5-1

Long Time:操作系统定义的长时间
如:Format("2010-5-1 9:8:5", "Long Time")=9:08:05

Medium Time:带AM/PM(上午/下午)的12小时制,不带秒
如:Format("2010-5-1 9:8:5", "Medium Time")=09:08 上午

Short Time:24时制的时间,不带秒
如:Format("2010-5-1 9:8:5", "Short Time")=09:08

2、自定义格式
C:格式化为国标的日期和时间
如:Format("2010-5-1 9:8:5", "c")=2010/5/1 9:08:05

y:一年中的第几天(1-366)
如:Format("2010-5-1 9:8:5", "y")=121

yy:两位数的年份(00-99)
如:Format("2010-5-1 9:8:5", "yy")=10

yyy:上面的 yy 与 y 结合在一起
"如:Format("2010-5-1 9:8:5", "yyy")=10121
    Format("2010-5-1 9:8:5", "yy年第y天")=10年第121天

yyyy:四位数的年份(0100-9999)
如:Format("2010-5-1 9:8:5", "yyyy")=2010

d:一个月中的第几天(1-31)
如:Format("2010-5-1 9:8:5", "d")=1

dd:与 d 相同,但不足两位时补足 0
如:Format("2010-5-1 9:8:5", "dd")=01

ddd:三个英文字母表示的星期几
如:Format("2010-5-1 9:8:5", "ddd")="Sat"

dddd:英文表示的星期几
如:Format("2010-5-1 9:8:5", "dddd")="Saturday"

ddddd:显示标准日期
如:Format("2010-5-1 9:8:5", "ddddd")=2010/5/1

dddddd:长日期
如:Format("2010-5-1 9:8:5", "dddddd")=2010年5月1日

w:一个星期中的第几天(始于周日,周日为1)
如:Format("2010-5-1 9:8:5", "w")=7

ww:一年中的第几周
如:Format("2010-5-1 9:8:5", "ww")=18

m:月份数(当用于时间时,也可以表时为分钟)
如:Format("2010-5-1 9:8:5", "m")=5

mm:当小于10时带前导0的月数(当用于时间时,也可以表示为两位数的分钟数)
如:Format("2010-5-1 9:8:5", "mm")=05

mmm:三个英文字母表示的月份数
如:Format("2010-1-1 9:8:5", "mmm")="Jan"

mmmm:英文表示的月份数
如:Format("2010-1-1 9:8:5", "mmmm")="January"

q:一年中的第几季(1-4)
如:Format("2010-5-1 9:8:5", "q")=2

aaa:中文表示的周几
如:Format("2010-5-1 9:8:5", "aaa")=周六

aaaa:中文表示的星期几
如:Format("2010-5-1 9:8:5", "aaaa")=星期六

h:小时数(0-23)
如:Format("2010-5-1 9:8:5", "h")=9

h:两位数表示的小时数
如:Format("2010-5-1 9:8:5", "hh")=09

n:分钟数(0-59)
如:Format("2010-5-1 9:8:5", "n")=8

nn:两位数表示的分钟数(00-59)
如:Format("2010-5-1 9:8:5", "nn")=08

s:秒数(0-59)
如:Format("2010-5-1 9:8:5", "s")=5

ss:两位数表示的秒数(00-59)
如:Format("2010-5-1 9:8:5", "ss")=05

ttttt:标准时间,当小时数小于10时不带0,与 h:mm:ss 或 h:nn:ss 相同
如:Format("2010-5-1 9:8:5", "ttttt")=9:08:05

AM/PM:显示当前为AM或PM
如:Format("2010-5-1 11:59:59", "AM/PM")=AM
    Format("2010-5-1 12:0:0", "AM/PM")=PM

A/P:显示当前为A或P
与 AM/PM 一样,这里不再举例。
说明:
可以多种格式联合使用,如:
Format("2010-5-1 9:8:5", "dddddd aaaa")=2010年5月1日 星期六

三、文本格式

@:匹配位置插入格式化文本,如:
在"abcde"前插入文本"X",代码为:Format("abcde", "X@")=Xabcde
在"abcde"第1位字符后面插入文本"X",代码为:Format("abcde", "@X")=aXbcde
在"abcde"第2位字符后面插入文本"X",代码为:Format("abcde", "@@X")=abXcde
在"abcde"第3位字符后面插入文本"X",代码为:Format("abcde", "@@@X")=abcXde
当点位符@比原文本字符串多时,刚在相应位置上添加空格,如:
Format("abc", "X@@@@")="X abc"
Format("abc", "X@@@@@")="X  abc"
Format("t", "@@a@")="  at"(空格空格at)

与!配合可从后面截取一段文本,如:
截取"abcde"后面1个字符文本,代码为:Format("abcde", "!@")=e
截取"abcde"后面2个字符文本,代码为:Format("abcde", "!@@")=de
截取"abcde"后面3个字符文本,代码为:Format("abcde", "!@@@")=cde
截取"abcde"后面两位,并在前面添加"XY",代码为:Format("abcde", "!XY@@")=Xyde


&:字符占位符,与@基本相同,这里不再赘述。


<:强制将所有字符以小写格式显示。
如:Format$("I Love You", "<")=i love you


>:强制将所有字符以大写格式显示。
如:Format$("I Love You", ">")=I LOVE YOU

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-4-23 10:54 | 显示全部楼层
Fso读取文本文件:
Sub test2()
Dim Fso, Fold, F, TxtFile, Txtstr, i&, j&, s, r&
Set Fso = CreateObject("scripting.filesystemobject")
Set Fold = Fso.getfolder(ThisWorkbook.Path & "\客户提供数据信息")
For Each F In Fold.Files
    If Fso.getextensionname(F) = "txt" Then
        Set TxtFile = Fso.opentextfile(F)
        Txtstr = TxtFile.readall
        Txtstr = Split(Txtstr, vbCrLf)
        For i = 0 To UBound(Txtstr)
            r = r + 1
            s = Split(Txtstr(i), vbTab)
            For j = 0 To UBound(s)
                Cells(r, j + 1) = "'" & s(j)
            Next j
        Next i
    End If
Next F
End Sub

Sub test3()
Dim Fso, Fold, F, TxtFile, Txtstr, i&, j&, s, r&
Set Fso = CreateObject("scripting.filesystemobject")
Set Fold = Fso.getfolder(ThisWorkbook.Path & "\客户提供数据信息")
For Each F In Fold.Files
    If Fso.getextensionname(F) = "txt" Then
        Set TxtFile = Fso.opentextfile(F)
        Do Until TxtFile.atendofstream
            s = TxtFile.readline
            If s <> "" Then
                r = r + 1
                s = Split(s, vbTab)
                Cells(r, 1).Resize(1, UBound(s) + 1) = s
            End If
        Loop
    End If
Next F
End Sub
txt转xls.rar (204.88 KB, 下载次数: 36)

TA的精华主题

TA的得分主题

 楼主| 发表于 2013-5-16 16:26 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
本帖最后由 小花鹿 于 2013-5-16 18:19 编辑

以下资料来自本站,放在这里是为了查找方便。

正则表达式有关资料:
正则表达式综合学习笔记.rar (17.48 KB, 下载次数: 52)

正则表达式30分钟入门教程.rar (15.41 KB, 下载次数: 50)

深入浅出之正则表达式.rar (24.3 KB, 下载次数: 49)

自学正则表达式过程分享.rar (39.84 KB, 下载次数: 47)

正则表达式元字符完整列表及行为说明.rar (5.66 KB, 下载次数: 50)

常用正则表达式大全.rar (4.87 KB, 下载次数: 48)
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-11-17 13:20 , Processed in 0.050038 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

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