【Excel VBA】For...Next Counter Loop

https://docs.microsoft.com/zh-cn/dotnet/visual-basic/language-reference/statements/for-next-statement

1. Simple Loop

在这里插入图片描述
If I come across a negative value then leaves the loop

在这里插入图片描述
从后往前loop backward

2. Nested loop

在这里插入图片描述
两个Loop:
(1). 先在每个cell里循环,找出Text和number的部分=》例如row 1, 分别是AT \ 1030
(2). 再每行循环

Sub For_Next_Loop_in_Text()
    Dim i As Long 'for looping inside each cell
    Dim myValue As String
    Dim NumFound As Long
    Dim TxtFound As String
    Dim r As Long 'for looping through rows
    LastRow = Range("A" & Rows.Count).End(xlUp).Row
    
    ' outside loop, 每行循环
    For r = StartRow To LastRow
        myValue = Range("A" & r).Value
        ' inside loop,从i=1到len(myvalue)每个字符循环,如果是number,则+=到NumFound
        For i = 1 To VBA.Len(myValue)
            
            If IsNumeric(VBA.Mid(myValue, i, 1)) Then
                NumFound = NumFound & Mid(myValue, i, 1)
            
            ElseIf Not IsNumeric(Mid(myValue, i, 1)) Then
                TxtFound = TxtFound & Mid(myValue, i, 1)
            End If
            
        Next i
        ' 将number和text的部分分别赋值到不同cell
        Range("H" & r).Value = TxtFound
        Range("I" & r).Value = NumFound
        ' 每行loop后,存number和text的变量归零
        NumFound = 0
        TxtFound = ""
        
    Next r
    
End Sub

在这里插入图片描述

Mid()
函数返回给定输入字符串中指定数量的字符。
语法Mid(String,start[,Length])

Private Sub Constant_demo_Click()
       Dim var as Variant
       var = "Microsoft VBScript"
       msgbox("Line 1 : " & Mid(var,2))
       msgbox("Line 2 : " & Mid(var,2,5))
       msgbox("Line 3 : " & Mid(var,5,7))
End Sub

执行以上代码,得到:

Line 1 : icrosoft VBScript
Line 2 : icros
Line 3 : osoft V
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: excel vba中的outlook .send方法是用来发送邮件的。该方法可以在vba代码中调用outlook应用程序,并使用指定的邮件信息发送邮件。使用该方法需要先创建一个outlook应用程序对象,然后使用该对象的createitem方法创建一个邮件对象,设置邮件的各种属性,最后调用.send方法发送邮件。该方法可以用于自动化发送邮件,提高工作效率。 ### 回答2: Excel VBA Outlook .Send方法是一种在Excel宏中使用Outlook发送电子邮件的方法。使用此方法,您可以在Excel中创建电子邮件模板,包括附件、收件人、主题、内容等,并通过Outlook发送该电子邮件。下面是关于Excel VBA Outlook .Send方法的详细解释。 1.语法: Outlook .Send 方法语法如下: expression.Send expression必需。代表 Outlook Application 对象的变量。 2.参数: 此方法没有必选参数,如您只是简单地发送电子邮件,您可以直接调用此方法。 3.返回值: 此方法不返回任何值。 4.示例: 下面是基于ID号发送 Outlook 电子邮件的示例: Sub send_Outlook_Email() Dim OutApp As Object Dim OutMail As Object Dim strbody As String Set OutApp = CreateObject("Outlook.Application") Set OutMail = OutApp.CreateItem(0) strbody = "Dear " & "Name" & "," & vbNewLine & vbNewLine & _ "This is a test email." & vbNewLine & vbNewLine & _ "Regards," & vbNewLine & _ "My Name" On Error Resume Next With OutMail .To = "recipient@domain.com" .CC = "" .BCC = "" .Subject = "Test Email" .Body = strbody .Attachments.Add ("C:\test.txt") .Send End With On Error GoTo 0 Set OutMail = Nothing Set OutApp = Nothing End Sub 在上述示例代码中,CreateObject 函数用于创建 Outlook 应用程序对象,之后,我们使用 CreateItem 函数创建了一个 MailItem 对象。 接下来,我们设置了各种电子邮件属性,例如 收件人、抄送、主题、正文等。最后,我们附加了一个文本文件,并调用 Send 方法从 OutMail 对象发送电子邮件。 5.注意事项: 在使用Outlook VBA Send方法时,您必须让Outlook应用程序运行在后台。如果Outlook应用程序没有启动,那么您必须在发送电子邮件之前启动它。 在VBA代码中使用Outlook应用程序需要授予许可证。如果Make Object Visible的属性未设置为True,则不会显示Outlook应用程序。 ### 回答3: Excel VBA中的Outlook .send方法是用于向Outlook发送邮件的一个方法。它允许开发人员将Excel工作簿中的数据或者信息,通过Outlook以电子邮件的形式发送出去。 使用Outlook .send方法的开发人员需要在Excel VBA项目中添加对Outlook的引用,然后使用Outlook对象模型中的相关方法和属性,来组织邮件的发送。在Outlook .send方法中,通过创建MailItem对象并对地址、主题、正文等属性进行设置,来完成邮件的构建。最后将MailItem对象使用.send方法发送出去即可。 此外,Outlook .send方法还允许开发人员定制电子邮件的各种属性和附件,例如,可以添加BCC、CC、重要性、请求回执、HTML格式等等。同时,Outlook .send方法也支持多个收件人接收邮件,并且能够将邮件分类和存档,使得邮件管理更加方便和高效。 总之,Outlook .send方法能够为Excel VBA程序开发人员提供一个可靠便捷的邮件发送方案,同时还具备较高的灵活性和可定制性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值