• 热点
  • 图片
  • 科技
  • 娱乐
  • 游戏
  • 体育
  • 汽车
  • 财经
  • 搞笑
  • 军事
  • 国际
  • 时尚
  • 旅游
  • 探索
  • 育儿
  • 养生
  • 美文
  • 历史
  • 美食
  • 当前位置: 小苹果范文网 > 旅游 > 正文

    工作总结【VBA自学语句】:每日工作总结经典语句

    时间:2018-07-12 20:01:36 来源:小苹果范文网 本文已影响 小苹果范文网手机站

    1、Application.CommandBars("Worksheet Menu Bar").Enabled = false

    2、cells(activecell.row,"b").value '活动单元格所在行B列单元格中的值

    3、Sub CheckSheet()'如果当前工作薄中没有名为kk的工作表的话,就增加一张名为kk的工作表,并将其排在工作表从左至右顺序排列的最左边的位置,即排在第一的位置 Dim shtSheet As Worksheet For Each shtSheet In Sheets If shtSheet.Name = "KK" Then Exit Sub Next shtSheet Set shtSheet = Sheets.Add(Before:=Sheets(1)) shtSheet.Name = "KK"End Sub

    4、Sheet1.ListBox1.List = Array("一月", "二月", "三月", "四月")'一次性增加项目

    5、Sheet2.Rows(1).Value = Sheet1.Rows(1).Value'将一个表中的一行全部拷贝到另一个表中

    6、Sub pro_cell()'将此代码放入sheet1,则me=sheet1,主要是认识meMe.UnprotectCells.Locked = FalseRange("D11:E11").Locked = TrueMe.ProtectEnd Sub

    7、Application.CommandBars("Ply").Enabled = False'工作表标签上快捷菜单失效

    8、Sub aa()'把B1到B12单元格的数据填入c1到c12For i = 1 To 12Range("C" & i) = Range("B" & i)Next iEnd Sub

    9、ActiveCell.AddCommentSelection.Font.Size = 12'在点选的单元格插入批注,字体为12号

    10、Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean) Cancel = TrueEnd Sub

    11、ScrollArea 属性参阅应用于示例特性以 A1 样式的区域引用形式返回或设置允许滚动的区域。用户不能选定滚动区域之外的单元格。String 类型,可读写。说明可将本属性设置为空字符串 ("") 以允许对整张工作表内所有单元格的选定。示例本示例设置第一张工作表的滚动区域。Worksheets(1).ScrollArea = "a1:f10"12\if application.max([a1:e1])=10 thenmsgbox""commandbutton1.enabled=false'A1—E1最大的数值达到10时,自动弹出对话框,并冻结按钮

    12、本示例将更改的单元格的颜色设为蓝色。Private Sub Worksheet_Change(ByVal Target as Range) Target.Font.ColorIndex = 5End Sub

    13、Sub test()'求和Dim rng As Range, rng2 As RangeFor Each rng In ActiveSheet.UsedRange.Columns Set rng2 = Range(Cells(1, rng.Column), Cells(Cells(65536, rng.Column).End(xlUp).Row, rng.Column)) rng2.Cells(rng2.Cells.Count).Offset(1, 0) = WorksheetFunction.Sum(rng2)Next rngEnd Sub

    14、将工作薄中的全部n张工作表都在sheet1中建上链接Sub test2()Dim Pt As RangeDim i As IntegerWith Sheet1 Set Pt = .Range("a1") For i = 2 To ThisWorkbook.Worksheets.Count .Hyperlinks.Add Anchor:=Pt, Address:="", SubAddress:=Worksheets(i).Name & "!A1" Set Pt = Pt.Offset(1, 0) Next iEnd WithEnd Sub

    15、保存所有打开的工作簿,然后退出 Microsoft Excel。For Each w In Application.Workbooks w.SaveNext wApplication.Quit

    16、让form标题栏上的关闭按钮失效Private Sub UserForm_QueryClose(Cancel As Integer, CloseMode As Integer)If CloseMode 《》 1 Then Cancel = TrueEnd Sub

    17、Sub countsh()'获得工作表的总数MsgBox Sheets.CountEnd Sub

    18、Sub IE()'打开个人网页ActiveWorkbook.FollowHyperlink "about:blank"SendKeys "{F4}ykk1976.anyp.cn{ENTER}", TrueEnd Sub

    19、Sub delback()'一次性删除工作簿中所有工作表的背景For Each shtSheet In Sheets shtSheet.SetBackgroundPicture Filename:="" Next shtSheetEnd Sub

    20、[a1].formula="=b1+c1"'A1中设定公式为=B1+C1

    21、Private Sub CommandButton1_Click()'将A1到C6中大于=3的数依次放入E列Dim i As Longr = 1For Each i In Range("a1:c6") If i 》 =3 Then Cells(r, 5) = i: r = r + 1NextEnd Sub

    22、Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)'显示带数字的表名b = Split(Sh.Name, "(")On Error GoTo ssnum = CInt(Left(b(1), Len(b(1)) - 1))If num 》= 1 And num 《 20 ThenMsgBox Sh.NameEnd IfExit Subss:MsgBox "error", 16, ""End Sub

    23、Sub Test()'选择所有工作表名以"业报"开头的工作表或头两个字是业报的报表名引用Set Sh = ActiveSheetIf Left(Sh.Name, 2) = "业报" Then ' 或if sh.name like"业报*"thenMsgBox "你成功了", 64, ""End IfEnd Sub

    24、1.建立文件夹的方法MkDir "D:\Music"2.打开文件夹的方法ActiveWorkbook.FollowHyperlink Address:="D:\Music", NewWindow:=True

    25、在当前工作表翻页 Application.SendKeys "{PGUP}", True Application.SendKeys "{PGDN}", True或者 ActiveWindow.LargeScroll Down:=1 ActiveWindow.LargeScroll Down:=-1

    26、当Target = "*小计"时如何写,*代表任何字符。 if instr(target.value,"小计")《》0 thenPrivate Sub Worksheet_SelectionChange(ByVal Target As Range)If Target.Value Like "*小计" Then MsgBox "OK"End Sub

    27、ActiveCell.FormulaR1C1 = "=SUM(R[1]C:R[14]C,R[59]C:R[78]C)"这是相对引用的写法:根据推算你的函数是放在"AD6"单元格你的函数:=SUM(R[1]C:R[14]C 中的 "R"表示行 "C"表示列。R[1]表示"AD6+1行",C表示"列没有变化,就是同列"那么:R[1]C就表示AD7同理,R[14]表示AD6+14行,表示:AD20。以此类推。

    28、Private Sub CommandButton1_Click()'将A1到C6中大于=3的数依次放入E列Dim i As LongDim iRng As RangeFor Each iRng In Sheets(1).Range("a1:c6") If iRng.Value 》= 3 Then i = i + 1 Sheets(1).Range("E" & i).Value = iRng.Value End IfNextEnd Sub

    29、工作表中的窗体按钮禁用后,按钮形状不变,字体不变,从外表上无法看出其已禁用,如何设置属性使其像控件按纽那样明显的禁用?With ActiveSheet.Buttons(1) .Enabled = False ActiveSheet.Shapes(.Caption).DrawingObject.Font.ColorIndex = 15 End With復原的方法 With ActiveSheet.Buttons(1) .Enabled = True ActiveSheet.Shapes(.Caption).DrawingObject.Font.ColorIndex = xlAutomatic End With

    30、Private Sub Worksheet_SelectionChange(ByVal Target As Range'选定A1时要输入密码If Target.Address = "$A$1" Then A = InputBox("请输入密码", "officefans") If A = 1 Then [A1].Select Else [A2].SelectEnd IfEnd Sub

    31、如何将工作薄中的命名单元格成批删除!Dim Item As Name For Each Item In ActiveWorkbook.Names Item.Delete Next Item

    32、平时只能看到表1,如要看表2和表3,只能通过表1的链接打开,且表2和表3回到表1后,又不可见。Private Sub Worksheet_SelectionChange(ByVal Target As Range) If Target.Address = "$A$3" Then '当点击"$A$3"单元格时... Sheet2.Visible = 1 '取消隐藏 Sheet2.Activate '激活 ActiveSheet.Range("A1").SelectEnd IfIf Target.Address = "$A$6" ThenSheet3.Visible = 1 '取消隐藏Sheet3.ActivateActiveSheet.Range("A1").SelectEnd IfEnd Sub

    33、将a2单元格内容替换为a1内容ActiveCell.Replace What:=[a2], Replacement:=[a1]

    34、如果是要填入名称,则:Private Sub Worksheet_SelectionChange(ByVal Target As Range)Selection.Value = ComboBox1.column(1)End Sub如果是要填入代码和名称的组合 :Private Sub Worksheet_SelectionChange(ByVal Target As Range)Selection.Value = cstr(ComboBox1.column(0))+" "+combobox1.column(1)End SubPrivate Sub Worksheet_SelectionChange(ByVal Target As Range)Selection.Value = ComboBox1.ValueEnd SubPrivate Sub Worksheet_SelectionChange(ByVal Target As Range) 'target.row 代表行号 'target.column 代表列号 i=target.row '获取行号 j=target.column '获取列号End Sub

    35、当激活工作表时,本示例对 A1:A10 区域进行排序。Private Sub Worksheet_Activate() Range("a1:a10").Sort Key1:=Range("a1"), Order:=xlAscendingEnd Sub

    36、BeforePrint 事件参阅应用于示例特性在打印指定工作簿(或者其中的任何内容)之前,产生此事件。Private Sub Workbook_BeforePrint(Cancel As Boolean)Cancel 当事件产生时为 False。如果该事件过程将本参数设为 True,则当该过程运行结束之后不打印工作簿。示例本示例在打印之前对当前活动工作簿的所有工作表重新计算。Private Sub Workbook_BeforePrint(Cancel As Boolean) For Each wk in Worksheets wk.Calculate NextEnd Sub

    37、Open 事件参阅应用于示例特性打开工作簿时,将产生本事件。Private Sub Workbook_Open()示例每次打开工作簿时,本示例都最大化 Microsoft Excel 窗口。Private Sub Workbook_Open() Application.WindowState = xlMaximizedEnd Sub

    38、ActiveSheet 属性参阅应用于示例特性返回一对象,该对象代表活动工作簿中的,或者指定的窗口或工作簿中的活动工作表(最上面的工作表)。只读。如果没有活动的工作表,则返回 Nothing。说明如果未给出对象识别符,本属性返回活动工作簿中的活动工作表。如果某一工作簿在若干个窗口中出现,那么该工作簿的 ActiveSheet 属性在不同窗口中可能不同。示例本示例显示活动工作表的名称。MsgBox "The name of the active sheet is " & ActiveSheet.Name

    39、Calculate 方法参阅应用于示例特性计算所有打开的工作簿、工作簿中的一张特定的工作表或者工作表中指定区域的单元格,如下表所示:要计算 依照本示例 所有打开的工作簿 Application.Calculate (或只是 Calculate) 指定工作表 指定工作表 指定区域 Worksheets(1).Rows(2).Calculate expression.Calculateexpression 对于 Application 对象可选,对于 Worksheet 对象和 Range 对象必需。该表达式返回"应用于"列表中的对象之一。示例本示例计算 Sheet1 已用区域中 A 列、B 列和 C 列的公式。Worksheets("Sheet1").UsedRange.Columns("A:C").Calculate程序的核心是算法问题

    40、End 属性参阅应用于示例特性返回一个 Range 对象,该对象代表包含源区域的区域尾端的单元格。等同于按键 End+ 向上键、End+ 向下键、End+ 向左键或 End+ 向右键。Range 对象,只读。expression.End(Direction)expression 必需。 该表达式返回"应用于"列表中的对象之一。Direction XlDirection 类型,必需。所要移动的方向。XlDirection 可为 XlDirection 常量之一。 xlDown xlToRight xlToLeft xlUp 示例本示例选定包含单元格 B4 的区域中 B 列顶端的单元格。Range("B4").End(xlUp).Select本示例选定包含单元格 B4 的区域中第 4 行尾端的单元格。Range("B4").End(xlToRight).Select本示例将选定区域从单元格 B4 延伸至第四行最后一个包含数据的单元格。Worksheets("Sheet1").ActivateRange("B4", Range("B4").End(xlToRight)).Select

    41、应用于 CellFormat 和 Range 对象的 Locked 属性。本示例解除对 Sheet1 中 A1:G37 区域单元格的锁定,以便当该工作表受保护时也可对这些单元格进行修改。Worksheets("Sheet1").Range("A1:G37").Locked = FalseWorksheets("Sheet1").Protect

    42、Next 属性参阅应用于示例特性返回一个 Chart、Range 或 Worksheet 对象,该对象代表下一个工作表或单元格。只读。说明如果指定对象为区域,则本属性的作用是仿效 Tab,但本属性只是返回下一单元格,并不选定它。在处于保护状态的工作表中,本属性返回下一个未锁定单元格。在未保护的工作表中,本属性总是返回紧靠指定单元格右边的单元格。示例本示例选定 sheet1 中下一个未锁定单元格。如果 sheet1 未保护,选定的单元格将是紧靠活动单元格右边的单元格。Worksheets("Sheet1").ActivateActiveCell.Next.Select

    43、想通过target来设置(A1:A10)区域内有改动,就发生此事件。不知道如何if target.row = 1 and target.column 《=10 thenSub 列举菜单项()Dim r, s, i As Integerr = 1For i = 1 To CommandBars.Count ActiveSheet.Cells(r, 1) = "CommandBars(" & i & ").Name:" & CommandBars(i).Name r = r + 1 For s = 1 To CommandBars(i).Controls.Count ActiveSheet.Cells(r, 1) = s & "、" & CommandBars(i).Controls(s).Caption r = r + 1 NextNextEnd Sub

    44、本示例设置 Microsoft Excel 每当打开包含链接的文件时,询问用户是否更新链接。Application.AskToUpdateLinks = True

    45、自定义函数Public Function Now1()Dim string1 As String string1 = VBA.Date Now1 = string1End Function

    46、复制Sub copy1()Sheet2.Range("C5:C10").Copy Sheet1.Range("C5:C10")End Sub

    47、如何统计表中sheet的个数?msgbox sheets.countColumns("G:G").Select

    48、 Selection.EntireColumn.Hidden = True这样隐藏有个毛病,如何解决?如果A1:G1单元格合并的话,就把A:G列均隐藏了。Columns("G:G").EntireColumn.Hidden = True

    49、在VBA中引用excel函数的方法1). Worksheets("Sheet1").Range("A1").Formula = "=$A$4+$A$10"2). Sheet1.Cells(1,1).Formula = "=" & Sheets(iii).Name & "!R1C4" 在宏中用R1C1方式写时表格1的A1中会在写为"=Sheet2!$D$1"用这种方式,想用什么函数就用什么函数.

    50、选定下(上)一个工作表sheets(activesheet.index-1).selectsheets(activesheet.index+1).select

    51、Private Sub Workbook_Open() ActiveWindow.DisplayWorkbookTabs = False '取消工作表标签 Application.CommandBars("Sheet").Controls(1).Enabled = False '格式_工作表不能重命名 Application.CommandBars.FindControl(ID:=889).Enabled = False '右键菜单不能重命名End Sub

    52、 [a65536].End(xlUp'A列从下往上第一个非空的单元格

    53、Sub macro()Set rng = Range("C11:F13") 定义RNG为一个单元格区域For Each cel In rng 定义CEL为RNG中的一个任一单元格colo = cel.Interior.ColorIndex 定义 COLO 为单元格CEL的填充颜色If colo 《》 -4142 Then 如果COLO的值不等于-4142 iR = [b65536].End(xlUp).Row + 1 IR等于B列数据区域的行数+1If [a65535].End(xlUp).Value 《》 Cells(cel.Row, 2) Then Cells(iR, 1) = Cells(cel.Row, 2) 如果A列最后一个非空值单元格 不等于Cells(cel.Row, 2) 的值 那么单元格Cells(iR, 1) 的值等于Cells(cel.Row, 2) 的值 CEL.ROW是C11:F13中任意单元格的行号Cells(iR, 2) = Cells(10, cel.Column) Cells(iR, 3) = cel.ValueCells(iR, 4) = IIf(colo = 36, "Yellow", "Red") Cells(iR, 4) 的值如果colo = 36那么值为"Yellow",否则值为"RED"nextEnd Sub

    54、Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)'**********运行数据日志记录**********Dim rng As Range If ActiveSheet.Name 《》 "主界面" And ActiveSheet.Name 《》 "目录索引" Then For Each rng In Target.Cells Changecell = ActiveSheet.Name & ",单元格:" & rng.Address(0, 0) & ",更改为:" & rng.value & "。更改时间:" & Now CritOrAddtext Next End IfEnd Sub

    55、ActiveSheet.Unprotect '撤销当前工作表保护If ActiveSheet.Name 《》 "主界面" And ActiveSheet.Name 《》 "目录索引" And Target.Row 》 3 Then '行变色On Error Resume Next[ChangColor_With].FormatConditions.DeleteTarget.EntireRow.Name = "ChangColor_With"With [ChangColor_With].FormatConditions .Delete .Add xlExpression, , "TRUE" .Item(1).Interior.ColorIndex = 4End WithEnd IfActiveSheet.Protect

    56、在C1中弄个下拉无表,实际是有效性,你可以选择A1:A4为C1单元格有效性的序列数据源,如果说C1不与A1:A4在同一表,则不能这么用,应当先对A1:A4命名,然后把数据源改为名称.

    57、自动增加工作表进入宏命令编辑窗口,在Sub 自动增加工作表()命令后依次键入如下宏命令内容:Dim i&, userintoi = 0userinto = InputBox("输入插入工作表数量:")If IsNumeric(userinto) = True ThenDo Until i = userintoWorksheets.Addi = i + 1LoopEnd IfEnd Sub

    58、方法一(共享级锁定): 1、先对EXCEL文件进行一般的VBAProject"工程密码保护。 2、打开要保护的文件,选择:工具---》保护---》保护并共享工作簿---》以追踪修订方式共享--》输入密码--》保存文件。 完成后,当你打开"VBAProject"工程属性时,就将会提示:"工程不可看!"方法二(推荐,破坏型锁定): 用16进制编辑工具,如WinHex、Ultraedit-32(可到此下载)等,再历害点的人完全可以用debug命令来做......用以上软件打开EXCEL文件,查找定位以下地方:ID="{00000000-0000-0000-0000-000000000000}" 注:实际显示不会全部为0 此时,你只要将其中的字节随便修改一下即可。保存再打开,就会发现大功告成! 当然,在修改前最好做好你的文档备份。至于恢复只要将改动过的地方还原即可(只要你记住了呵呵)。顺便说一句,这种方法仍然是可破解的,因为加密总是相对的 。

    59、Sub AddComments()'自動對ActiveSheet所有有公式格位加上註解 Set RG = Cells.SpecialCells(xlCellTypeFormulas) For Each c In RG c.AddComment c.Comment.Text Text:=c.Formula Next cEnd SubSub De_Comments()'自動消除所有註解 Set RG = Cells.SpecialCells(xlCellTypeFormulas) For Each c In RG c.ClearComments Next cEnd Sub

    60、如何在Excel里使用定时器 用过 Excel 97 里的加载宏 "定时保存" 吗?可惜它的源程序是加密的,现在就上传一篇介绍实现它的文档。

    在 Office 里有个方法是 application.ontime ,具体函数如下:expression.OnTime(EarliestTime, Procedure, LatestTime, Schedule) 如果想进一步了解,请参阅 Excel 的帮助。 这个函数是用来安排一个过程在将来的特定时间运行,(可为某个日期的指定时间,也可为指定的时间段之后)。通过这个函数我们就可以在 Excel 里编写自己的定时程序了。下面就举两个例子来说明它。 1.在下午 17:00:00 的时候显示一个对话框。 Sub Run_it() Application.OnTime TimeValue("17:00:00"), "Show_my_msg" '设置定时器在 17:00:00 激活,激活后运行 Show_my_msg 。 End Sub Sub Show_my_msg() msg = MsgBox("现在是 17:00:00 !", vbInformation, "自定义信息") End Sub 2.模仿 Excel 97 里的 "自动保存宏",在这里定时 5 秒出现一次 Sub auto_open() MsgBox "欢迎你,在这篇文档里,每 5 秒出现一次保存的提示!", vbInformation, "请注意!" Call runtimer '打开文档时自动运行 End Sub Sub runtimer() Application.OnTime Now + TimeValue("00:00:05"), "saveit" ' Now + TimeValue("00:15:00") 指定在当前时间过 5 秒钟开始运行 Saveit 这个过程。 End Sub Sub SaveIt() msg = MsgBox("朋友,你已经工作很久了,现在就存盘吗?" & Chr(13) _ & "选择是:立刻存盘" & Chr(13) _ & "选择否:暂不存盘" & Chr(13) _ & "选择取消:不再出现这个提示", vbYesNoCancel + 64, "休息一会吧!") '提示用户保存当前活动文档。 If msg = vbYes Then ActiveWorkbook.Save Else If msg = vbCancel Then Exit Sub Call runtimer '如果用户没有选择取消就再次调用 Runtimer End Sub 以上只是两个简单的例子,有兴趣的话,可以利用 Application.Ontime 这个函数写出更多更有用的定时程序。 Sub Show_my_msg() msg = MsgBox("现在是 17:00:00 !", vbInformation, "自定义信息") End Sub 2.模仿 Excel 97 里的 "自动保存宏",在这里定时 5 秒出现一次 Sub auto_open() MsgBox "欢迎你,在这篇文档里,每 5 秒出现一次保存的提示!", vbInformation, "请注意!" Call runtimer '打开文档时自动运行 End Sub Sub runtimer() Application.OnTime Now + TimeValue("00:00:05"), "saveit" ' Now + TimeValue("00:15:00") 指定在当前时间过 5 秒钟开始运行 Saveit 这个过程。 End Sub接上面

    61、Excel 最重要的应用就是利用公式进行计算。无论输入是纯粹的数字运算,还是引用其他单元格计算,只要在一个单元格中输入公式,就能得到结果。这个直接显示结果的设计对于绝大多数场合来说都是适用的,但某些情况下就不那么让人满意了。比如说在做工程施工的预结算编写,使用Excel,既要写出工程量的计算式,也要看到它的结果,于是这样相同的公式在Excel里面要填两次,一次在文本格式的单元格中输入公式,一次是在数据格式的单元格中输入公式让Excel计算结果。如何既能看到公式又能看到结果呢?这个问题笔者认为可以从两个方面考虑:一种方法是所谓"已知结果,显示公式",先在数据格式单元格中输入公式让Excel计算结果,然后在相邻的单元格中看到公式;另一种方法所谓"已知公式,显示结果",就是先在一个文本格式的单元格中输入公式,在相邻的单元格中看到结果。★已知结果,显示公式假设C列为通过公式计算得到的结果(假设C1为"=A1+B1",或者直接是数字运算"=2+3"),而相邻的D列是你需要显示公式的地方(即D1应该显示为"=A1+B1"或者"=2+3")。

    1. 打开"工具"菜单选择"选项"命令,出现"选项"对话框。

    2.在"常规"选项卡中,选中"R1C1引用方式"选项。

    3. 定义名称,将"引用位置"由"=GET.CELL(6,Sheet1!RC[-1])"即可。这里的RC[-1]含义是如果在当前单元格的同行前一列单元格中有公式结果,则在当前单元格中得到公式内容,即在含公式结果单元格的同行后一列单元格显示公式内容;如果将RC[-1]改为RC[1],则在公式结果的同行前一列单元格显示公式内容。

    4. 如果"引用位置"中含有"RC[-1]",则在含公式结果单元格的同行后一列单元格中输入"=FormulaofResult"即可得到公式;如果"引用位置"中含有"RC[1]",则在含公式结果单元格的同行前一列单元格中输

    • 生活居家
    • 情感人生
    • 社会财经
    • 文化
    • 职场
    • 教育
    • 电脑上网