1.合并字符串
A1&A2
2.拆分字符串
LEFT(A2,SEARCH("-",A2)-1)
3.下拉选项
Data->Data validation->List

1.在工具栏上显示开发选项

2.新建个Module就可以在几个sheet里共享变量

Public cn As New ADODB.Connection
Public strCn As String
Public strCom As String
Public rs As New ADODB.Recordset
Public Sub Init()
Dim rs As New ADODB.Recordset
strCn = "Provider=sqloledb;Database=testdb;Uid=sa;Pwd=password;data source=dbname"
Set cn = Nothing
cn = New ADODB.Connection
cn.Open strCn
End Sub
Private Sub CommandButton1_Click()
'o = MsgBox("B1:" & Range("b1").Text & Range("b1").Value, vbOKOnly, "test")
Init
strCom = "exec testsp 2"
rs.Open strCom, cn, adOpenDynamic, adLockBatchOptimistic
Sheet1.Cells(1, 1).CopyFromRecordset rs
cn.Close
End Sub

3.添加下拉列表选项

ComboBox1.Clear
For Each testList In Sheet2.Rows 'Sheet2.Range("A1", "A6")
With ComboBox1
.AddItem testList.Value
End With
Next testList

4.在另一台电脑上,发现上面的连接数据库会发生错误

在open语句时总是提示说连接已经结束,后来将连接字符串改了下又可以

Public strConn As String, strSQL As String
Public conn As ADODB.Connection
Public Sub Init()
Set conn = New ADODB.Connection
'连接数据库的字符串
strConn = "Provider=SQLOLEDB.1;Persist Security Info=True;User ID=sa;Password=pwd;Initial Catalog=DBname;Data Source=DBServer;Connect Timeout=720; "
'打开数据库连接
conn.Open strConn
'该句和数据库连接字符串处的Connect Timeout=720,表示说如果语句运行时间很长,这两句可以延长vba的等待时间,没有这两句,vba往往会报查询超时。
conn.CommandTimeout = 720
End Sub

普通查询语句没问题,可是执行存储过程,稍微复杂一点的就会报错,应用程序定义或对象定义错误,后来才发现是存储过程必须加上这么一句

感谢万能的百度!
SET NOCOUNT ON

[求助] VBA调用存储过程的问题,在线等
http://club.excelhome.net/thread-1179098-1-1.html

执行带参数的存储过程也可以这么写

Dim CN As New ADODB.Connection
Dim iCmd As ADODB.Command
Const conn = "Provider = SQLOLEDB;" & _
"Data Source = DBServer;" & _
"Initial Catalog = DBName;User ID =sa;Password = pwd;"
CN.Open conn
Set iCmd = New ADODB.Command
With iCmd
.ActiveConnection = CN
.CommandTimeout = 120
.CommandType = adCmdStoredProc
.CommandText = "zConvertLunarSolar"
.Parameters.Refresh
.Parameters("@iyear") = 1966
.Parameters("@imon") = 5
.Parameters("@iday") = 3
.Parameters("@ihour") = 1
.Parameters("@imin") = 20
.Parameters("@IsLeapM") = False
.Parameters("@ToLunar") = True End With
Dim rs As New ADODB.Recordset
Set rs = iCmd.Execute
Sheet1.Cells(5, 5).CopyFromRecordset rs

5.含有VBA代码的Excel再次打开,代码居然全都不见了!坑爹啊!原来.xlsx是不支持保存含有这些宏,ActiveX的文件,需要保存为启用宏的工作簿。
另存为后,发现设计模式变为灰色,原来还要在文件里启动宏才可以正常工作!

6.VBA大多数语法跟VB.Net一样,但也有些许不同,真令人防不胜防

Split函数,str.Split(",")是错的,须写成Split(str,",")

Len函数,用法是Len(str),不是str.Length

数组类型Variant可以通过Redim来设置可变下标,获取最大和最小下标是用函数UBound(arr),LBound(arr),不是arr.Count()
    Dim pos() As Variant
    ReDim pos(colCnt)

另外,二维数组,比如从recordset返回的值,UBound(arr, 1)是数组最大列个数,UBound(arr, 2)才是最大行个数
   GetArray = rs.GetRows

Function里面的返回值,不要写成return i , 而要写成functioinName = i

Call Sub,不能有括号,不然会报错

7.得到返回记录集的行数
Fields.Item是返回的列,RecordCount总是返回-1,查了下,说第三个参数是1或者3的时候就可以得到RecordCount
rs.Open strSQL, conn,adOpenStatic, adLockReadOnly
rs.Open strSQL, conn,adOpenKeyset, adLockReadOnly
可是后来改了还是返回-1,原来是需要设置游标参数
rs.CursorLocation = adUseClient

Public Function CopyFromSQL(ByVal strSQL As String, ByVal sheetName As String, ByVal range As String, ByVal hrow As Integer, ByVal hCol As Integer) As Integer
Dim rs As New ADODB.Recordset
rs.CursorLocation = adUseClient
rs.Open strSQL, conn, adOpenKeyset, adLockReadOnly Sheets(sheetName).range(range).ClearContents
Sheets(sheetName).range(range).Borders.LineStyle = xlNone
Sheets(sheetName).range(range).Interior.Pattern = xlNone '行名
Dim rowCnt As Integer, colCnt As Integer, iCol As Integer
rowCnt = rs.RecordCount
colCnt = rs.Fields.Count
iCol = hCol
For Each Item In rs.Fields
Sheets(sheetName).Cells(hrow, iCol) = Item.name
iCol = iCol + 1
Next Item
iCol = iCol - 1
Sheets(sheetName).range(Cells(hrow + 1, hCol), Cells(hrow + 1 + rowCnt, iCol)).CopyFromRecordset rs
Sheets(sheetName).range(Cells(hrow, hCol), Cells(hrow, iCol)).Interior.ColorIndex = 17
Sheets(sheetName).range(Cells(hrow, hCol), Cells(hrow + rowCnt, iCol)).Borders.LineStyle = xlContinuous
rs.Close
conn.Close
CopyFromSQL = rowCnt
End Function

8.如果需要按了一个按钮后,填充另一个sheet的工作表,需要先用Activate语句,不然又报万能的“应用程序定义或者对象定义错误”!
PPSheet.Activate
CopyFromSQL strSQL, PPSheet, PPRange, irow, iCol

9.有一个奇怪的现象是执行过CopyFromRecordset后,填充到excel里面的数组字段显示成了日期格式
这个现象好像是忽然出现的,莫名其妙,数据库里返回的明明是数值字段,只不过前面一个字段是日期,后面的就变成了日期格式
目前还没找到解决办法。

10.数据库的字符串加了回车号,但显示回excel的时候并不会自动给换行,只好手动replace了

Sheets(PPSheet).Cells(irow, iCol) = Replace(value, Chr(13), vbCrLf)

11.VBA里面数组的类型为Variant,Function必须定义为这个类型才能返回
可以用Ubound(arr),LBound(arr)来得到最大和最小的下标,不能用length或者count
下面是一个十二宫位里画三方四正直线的代码
Public Sub ClearRange(ByVal sheetName As String, ByVal range As String)
If Len(range) > 0 Then
Sheets(sheetName).range(range).ClearContents
Sheets(sheetName).range(range).Borders.LineStyle = xlNone
Sheets(sheetName).range(range).Interior.Pattern = xlNone
End If
End Sub
Public Sub ClearCellArray(ByVal sheetName As String, ByVal pos As Variant)
For Each P In pos
Sheets(sheetName).range(P).value = ""
Next
End Sub
Public Sub ClearLine(ByVal sheetName As String)
For Each x In Sheets(sheetName).Shapes
If x.Type = msoLine Then
x.Delete
End If
Next
End Sub
Public Sub DrawForGongWei(ByVal sheetName As String, ByVal zhipos As Integer, ByVal pos As Variant)
Dim zmove As Integer, i As Integer, fromPos As String, toPos1 As String, toPos2 As String
'zhiPos = zhiId Mod 12
fromPos = pos(zhipos)
'San Fang
zmove = (zhipos + 12 + 4 * 1) Mod 12
toPos1 = pos(zmove)
DrawLine sheetName, fromPos, pos(zmove)
zmove = (zhipos + 12 + 4 * 2) Mod 12
toPos2 = pos(zmove)
DrawLine sheetName, fromPos, pos(zmove)
DrawLine sheetName, toPos1, toPos2
'Dui Gong
zmove = (zhipos + 18) Mod 12
DrawLine sheetName, fromPos, pos(zmove)
End Sub Public Function GetArrayPos(ByVal rangeStart As String, Optional offset As Integer = 2) As Variant
Dim str2 As String, str3 As String, str4 As String, str5 As String, str6 As String, str7 As String, str8 As String, str9 As String, str10 As String, str11 As String, str12 As String
Dim row As String, col As Integer
row = Sheet1.range(rangeStart).row
col = Sheet1.range(rangeStart).Column
size = Sheet1.range(rangeStart).Rows.Count
col = col - offset
str2 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
col = col - offset
str3 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
row = row - offset
str4 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
row = row - offset
str5 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
row = row - offset
str6 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
col = col + offset
str7 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
col = col + offset
str8 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
col = col + offset
str9 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
row = row + offset
str10 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
row = row + offset
str11 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0)
row = row + offset
str12 = Sheet1.Cells(row, col).Address(0, 0) & ":" & Sheet1.Cells(row + size - 1, col + size - 1).Address(0, 0) GetArrayPos = Array(rangeStart, str2, str3, str4, str5, str6, str7, str8, str9, str10, str11, str12)
End Function
Public Function GetArrayPos2(ByVal rangeStart As String, ByVal colCnt As Integer) As Variant
Dim pos() As Variant
ReDim pos(colCnt) Dim row As Integer, col As Integer, i As Integer
row = Sheet1.range(rangeStart).row
col = Sheet1.range(rangeStart).Column
rowOffset = Sheet1.range(rangeStart).Rows.Count
For i = 0 To colCnt - 1 Step 1
pos(i) = Sheet1.Cells(row, col + i).Address(0, 0) & ":" & Sheet1.Cells(row + rowOffset - 1, col + i).Address(0, 0)
Next i GetArrayPos2 = pos
End Function
Public Sub DrawLine(ByVal sheetName As String, ByVal fromPos As String, ByVal toPos As String)
Dim beginx As Integer, beginy As Integer, endx As Integer, endy As Integer
beginx = GetRangeXY(fromPos, True)
beginy = GetRangeXY(fromPos, False)
endx = GetRangeXY(toPos, True)
endy = GetRangeXY(toPos, False)
Sheets(sheetName).Shapes.AddLine beginx, beginy, endx, endy
End Sub
Public Function GetRangeXY(ByVal pos As String, ByVal isX As Boolean) As Integer
If isX Then
Dim left As Integer, width As Integer
left = range(pos).left
width = range(pos).width
GetRangeXY = left + width / 2
Else
Dim top As Integer, height As Integer
top = range(pos).top
height = range(pos).height
GetRangeXY = top + height / 2
End If
End Function

12.Open函数是必须放在ThisWorkbook里面才有效的,其它sheet里面不起作用

Private Sub Workbook_Open()
MsgBox "test"
End Sub

13.可以在Sheet1里面call Sheet2的函数,只需要在函数名前面加Sheet2就可以了

14.获取日期
curYear = Year(Now)

Excel开发VBA学习的更多相关文章

  1. VBA学习资料分享-1

    近年来,人工智能的概念深入人心,许多企业也正逐步或已推行办公自动化,寻求人力时间成本的降低,从而提升效益.对企业来说,要完全使用人工智能将工作流程自动化恐怕是没那么容易的,可以的话成本也不低,所以使用 ...

  2. 浅谈Excel开发:八 Excel 项目的安装部署

    前面几篇文章讲解了Excel开发的几个比较主要的也是比较重要的方面,比如菜单系统,Excel对象模型,自定义函数,RTD函数,异步自定义函数,用户自定义任务面板等,在实际开发中我们还会遇到各种“千奇百 ...

  3. 浅谈Excel开发:七 Excel 自定义任务窗体

    前面花了三篇文章讲解了Excel中的UDF函数,RTD函数和异步UDF函数,这些都是Excel开发中的重中之重.本文现在开始接着第二篇文章的菜单系统开始讲解Excel中可供开发的界面元素,本文要讲解的 ...

  4. 浅谈Excel开发:三 Excel 对象模型

    前一篇文章介绍了Excel中的菜单系统,在创建完菜单和工具栏之后,就要着手进行功能的开发了.不论您采用何种方式来开发Excel应用程序,了解Excel对象模型尤其重要,这些对象是您与Excel进行交互 ...

  5. 浅谈Excel开发:一 Excel 开发概述

        做Office相关的开发工作快一年多了,在这一年多里,在插件的开发中遇到了各种各样的问题和困难,还好同事们都很厉害,在和他们的交流讨论中学到了很多的知识.目前Office相关的开发资料是比较少 ...

  6. Excel开发

    浅谈Excel开发:九 Excel 开发中遇到的常见问题及解决方法   Excel开发过程中有时候会遇到各种奇怪的问题,下面就列出一些本人在开发中遇到的一些比较典型的问题,并给出了解决方法,希望对大家 ...

  7. Excel 开发概述

    浅谈Excel开发:一 Excel 开发概述 做Office相关的开发工作快一年多了,在这一年多里,在插件的开发中遇到了各种各样的问题和困难,还好同事们都很厉害,在和他们的交流讨论中学到了很多的知识. ...

  8. 【转载】浅谈Excel开发:一 Excel 开发概述

    博客园就是好,想要什么都给总结了,多谢 原文转载:http://www.cnblogs.com/yangecnu/p/Excel-Develpment-Introduction.html 做Offic ...

  9. 《C#微信开发系列(Top)-微信开发完整学习路线》

    年前就答应要将微信开发的学习路线整理给到大家,但是因为年后回来这段时间学校还有公司那边有很多事情需要兼顾,所以没能及时更新文章.今天特地花时间整理了下,话不多说,上图,希望对大家的学习有所帮助哈. 如 ...

随机推荐

  1. 计算机网络自顶向下方法第4章 网络层:数据平面 (Network layer)

    4.1 网络层概述  网络层主要功能为转发(将数据从路由器输入接口转移到合适的输出接口)和路由选择(端到端的路径选择),每台路由器都有一张转发表,用最长前缀匹配规则来转发. 4.1.1 转发和路由选择 ...

  2. PAT(B) 1037 在霍格沃茨找零钱(Java)

    题目链接:1037 在霍格沃茨找零钱 (20 point(s)) 题目描述 如果你是哈利·波特迷,你会知道魔法世界有它自己的货币系统 -- 就如海格告诉哈利的:"十七个银西可(Sickle) ...

  3. WUSTOJ 1344: still水题(Java)进制转换

    题目链接:1344: still水题 Description 送AC,不解释 Input 输入两个整数n和b,b表示该数的进制(包含2.8.16进制,多组数组) Output 输出该整数(10进制,每 ...

  4. Asp.netCore 的Startup 不继承接口

    有一个问题: Asp.netCore 的Startup 要实现 Config 和ConfigServie 方法, 为什么不接口约束呢. 进入源码: // // 摘要: // /// Specify t ...

  5. 3_PHP表达式_2_变量

    以下为学习孔祥盛主编的<PHP编程基础与实例教程>(第二版)所做的笔记. PHP变量可分为自定义变量和预定义变量. 以下所谈到的变量均为自定义变量. 1.变量的基本概念 PHP的变量名遵循 ...

  6. shell 实战 -- 基于一个服务启动,关闭,状态检查的脚本

    功能说明: check:检查服务状态,在开启,关闭,状态检查时都会用到这个函数,所以封装起来放到最前面 start:开启服务 stop:关闭服务 fstop:强制关闭 status:检查服务状态 ru ...

  7. [ICCV 2019] Weakly Supervised Object Detection With Segmentation Collaboration

    新在ICCV上发的弱监督物体检测文章,偷偷高兴一下,贴出我的poster,最近有点忙,话不多说,欢迎交流- https://arxiv.org/pdf/1904.00551.pdf http://op ...

  8. C++实现企业链表(单向链表的另外一种实现方式)

    LinkList.h #include <windows.h> #include <stdio.h> // 链表小结点 typedef struct LINKNODE { LI ...

  9. Oracle表空间满处理方式

    一.查询表空间常规语句 1.查询表空间使用情况 SELECT Upper(F.TABLESPACE_NAME)         "表空间名", D.TOT_GROOTTE_MB   ...

  10. RestFramework之视图组件

    一.视图组件的使用 在我们自己书写视图类时需要不断书写重复冗余的代码,看起来十分繁琐不简洁易见,当然rest_framework中的视图组件帮我们做到了一些必要的步骤,使我们节省了编写冗余代码的时间. ...