- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我看了看,发现了类似的问题,但它们似乎都是如何将一个列表添加到另一个列表的末尾。
我最近用我在 Excel 中使用的一种技术回答了一个问题,该技术依赖于创建第三列,并使用公式填充来连接每一行的 col1 和 col2。我认为必须有更好的方法来做到这一点,所以在 VBA 中进行了一些尝试,并从我能找到的问题中提出了以下问题。但现在我有几个问题:
有没有办法摆脱使用 x 数量的任意值设置第三个数组,这些值无论如何都会被替换? ReDim something maybe
总体上是否有更好/更整洁的方法来根据它们的位置组合来自 arr1 和 arr2 的元素,而无需 骑自行车通过每一个? (使用内置数组命令或其他)
(抱歉,如果这在某处重复了任何线程,我确实看过,老实说!)
Private Sub CommandButton1_Click()
Dim arr1() As Variant
Dim arr2() As Variant
Dim arr3() As Variant
Dim element As Variant
Dim pos As Integer
arr1 = Array("ONE", "TWO", "THREE")
arr2 = Array("1111", "2222", "3333")
arr3 = Array("x", "x", "x")
For Each element In arr1
pos = Application.WorksheetFunction.Match(element, arr1, False) - 1
arr3(pos) = arr1(pos) & arr2(pos)
'MsgBox (arr1(pos) & arr2(pos) & arr3(pos))
Next
'Where arr3 will equal ("ONE1111", "TWO2222", "THREE3333")
End Sub
最佳答案
为了扩展我的评论,您可能为此使用的任何代码都将循环遍历数组元素。内置代码的唯一区别是您看不到循环代码。下面是一些代码,可让您进行简单的函数调用,并且支持任意数量的输入数组。 JoinArrayElements
函数可以满足您的要求,您可以使用它而无需每次都编写代码来“循环遍历元素”。
Public Sub Main()
Dim arr1, arr2
arr1 = Array("ONE", "TWO", "THREE")
arr2 = Array("1111", "2222", "3333")
arr3 = Array("!@!@", "@#@#", "#$#$")
Debug.Print arrayToString(joinArrayElements(arr1, arr2))
Debug.Print arrayToString(joinArrayElements(arr1, arr2, arr3))
End Sub
Public Function arrayToString(arr As Variant) As String
Dim output As String
output = "["
If UBound(arr) - LBound(arr) > 0 Then
output = output & """" & arr(LBound(arr)) & """"
For index = LBound(arr) + 1 To UBound(arr)
output = output & ", " & """" & arr(index) & """"
Next
End If
output = output & "]"
arrayToString = output
End Function
Public Function joinArrayElements(ParamArray args() As Variant) As Variant
'Validation to add:
' Are all the passed parameters actual valid arrays?
' Are they all the same length?
Dim arrayNumber As Long
Dim index As Long
Dim arrOutput() As Variant
ReDim arrOutput(LBound(args(0)) To UBound(args(0)))
For arrayNumber = LBound(args) To UBound(args)
For index = LBound(args(0)) To UBound(args(0))
arrOutput(index) = arrOutput(index) & args(arrayNumber)(index)
Next
Next
joinArrayElements = arrOutput
End Function
这段代码的输出是:
["ONE1111", "TWO2222", "THREE3333"]
["ONE1111!@!@", "TWO2222@#@#", "THREE3333#$#$"]
关于arrays - 仅限 VBA - 是否有更简单的方法可以根据位置连接数组值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39649467/
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我们有自己的 http 服务器适配器,我们用它来托管多个站点。 本网站通过 https 运行。当我们尝试使用 chrome、firefox 或 safari 访问 url 时,它工作正常。该问题仅发生
让我从代码开始……请注意,这不是关于覆盖实例方法的问题——这纯粹涉及扩展方法。此代码用于 Unity3D 游戏引擎,版本 5.3.x public static class ExtentionMeth
我想知道如何开发一个只提供 iOS native 设置应用程序中的一些设置的应用程序,比如很多 cydia 调整,而跳板上没有图标?我的目标只是让一些开关和按钮在我的本地网络上发送命令。 最佳答案 在
好吧,我需要得到两个值来表示两个完整日期之间的距离(没有小时/时间)......在 MySQL 上我们有 PERIOD_DIFF 来获取两个日期之间的差异(只有月份和年份),但我也需要包括日期。 我有
这就是我想要做的。在我的 html 页面上,我必须有 4 种不同的字体大小,其中一种是 10px 20px 30px 40px 然后重置。 当我在 10px 上单击或滚动鼠标时,字体大小会更改并在 d
这个问题在这里已经有了答案: How can I transition height: 0; to height: auto; using CSS? (41 个回答) 关闭 4 年前。
我喜欢 JQuery Mobile,但我的页面中有许多与 JQuery Mobile 不兼容的自定义 Javascript。 我页面中的所有内容都工作正常,但是当我添加 JQuery Mobile 库
我正在尝试创建以下工具提示(不是其中的内容 - 只是框和箭头): 我在让箭头与主框正确融合时遇到问题。 我创建了一个 Fiddle here使用我目前拥有的代码。 您会注意到箭头看起来不错,但不是 1
我是 Javascript 新手。我正在尝试通过练习来学习它。我正在做的这个看起来并不难,但我有一个小问题。 我有一个包含 3 个文本输入和一个提交按钮的表单。通过按下按钮,我获得了字段值并使用这些值
当我将鼠标悬停在按钮上时,我希望菜单滑出。不知何故,只有当我将悬停效果添加到菜单本身而不是按钮时,它才会起作用。我在网上能找到的都是一样的(悬停效果附加到应该滑出的菜单,而不是按钮)。我该如何实现?j
我只想让我的应用程序横向,所以我使用这里提供的方法:i want to make my application only in landscape in android 简而言之,我正在将 andro
我需要将我的共享扩展限制为仅纵向模式。但到目前为止,还不行。有办法吗? @implementation UINavigationController -(BOOL)shouldAutorotate {
不知道是否有人已经看到这个错误。请注意,这仅发生在 Android 4.x 库存浏览器中。它已经在 Android 4 上的 Chrome、旧版浏览器、iOS、Blackberry OS6 和 7、P
如果内容大于容器,我正在尝试构建一个可在 x 和 y 方向滚动的表格。我还希望标题始终在顶部可见。我已经完成了第一部分的工作,标题始终在顶部可见,但是标题列的大小与表格的大小不匹配。 我创建了这个 f
当对图像应用 ImageFilter.blur 时,图像的边缘没有变化。 如何将模糊扩展到边缘? import 'dart:ui'; import 'package:flutter/material.
我正在为 Android 平板电脑编写应用程序。我希望 ScreenOrientation 始终处于“横向”状态,但应用程序应该能够旋转 180°。如果您将平板电脑倒置,则 View 应正确显示并旋转
我有一个带有属性装饰器的类。 class Dispatcher: def __init__(self, url): self._session = None @prop
我只想在模型的查询集中选择几个字段。我看到了这个链接:Django queryset only我以为我实现了它,但我仍然得到了整个查询集。 这是我的项目 View .py: from django.s
我看了看,发现了类似的问题,但它们似乎都是如何将一个列表添加到另一个列表的末尾。 我最近用我在 Excel 中使用的一种技术回答了一个问题,该技术依赖于创建第三列,并使用公式填充来连接每一行的 col
我是一名优秀的程序员,十分优秀!