- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在最近的 post我在 中演示了如何使用数组参数。 Application.Index()
函数(而不是单个索引)
以任何方向重新排列当前列的顺序(切换列、省略/删除列)。
Application.Index(data, {vertical rows array}, {horizontal columns array})
这种方法不需要循环,并且允许仅通过在 OP 中列出新列位置来定义任何新列顺序,例如通过
Array(1, 4, 2)
换句话说
Sub DeleteAndSwitch()
'[1]get data
Dim data: data = Sheet1.Range("A1:D4")
'[2]reorder columns via Array(1, 4, 2), i.e. get 1st column, 4th and 2nd column omitting the 3rd one
' (evaluation gets all existing rows as vertical 2-dim array)
data = Application.Index(data, Evaluate("row(1:" & UBound(data) & ")"), Array(1, 4, 2))
'[3]write to any target
Sheet2.Range("A1").Resize(UBound(data), UBound(data, 2)) = data
End Sub
相关评论问:
"I can slice a 2D array, I can eliminate column, reorder columns, but I cannot ►insert a column(s) slice in such an array...In fact, I can do it using iteration, but did you find a similar way to insert such a vertical slice?"
data
)通过
Column4Data = Application.Index(data, 0, 4)
产生一个基于 1 的 2 维“垂直”数组。
Application.Index(data, 0, 4) = Application.Index(data, 0, 1)
问题
Is there any possibility to insert a column(s) slice in an array (without iteration)?
Application.Index()
function
最佳答案
使用 Application.Index()
的锯齿状阵列方法
为了完整起见,我展示了这种方法,以证明 Application.Index()
的进一步且广泛未知的可能性。功能。
通过首先将(转置)切片添加到临时“数组数组”中,可以在第二步中通过 创建一个二维数组。双零 使用以下语法的参数(参见 [2]b
部分):
data = Application.Transpose(Application.Index(data, 0, 0))
Sub InsertSlices()
'Auth: https://stackoverflow.com/users/6460297/t-m
'[0]define extra array (or slice AND transpose from other data source)
Dim Extra: Extra = Array(100, 200, 300, 400) ' example data
'[1]get data
Dim data: data = Tabelle7.Range("A1:D4")
'[2]a) rewrite data as 1-dim array of sliced column arrays
data = Array(Extra, Slice(data, 1), Slice(data, 4), Slice(data, 2))
'~~~~~~~~~~~~~~~~~~~~~~~~~~~~
'[2]b) rebuild as 2-dim array
'~~~~~~~~~~~~~~~~~~~~~~~~~~~~
data = Application.Transpose(Application.Index(data, 0, 0))
'[3]write to any target
Tabelle7.Range("F1").Resize(UBound(data), UBound(data, 2)) = data
End Sub
Function Slice(DataArr, ByVal colNo As Long) As Variant()
'Purpose: return entire column data as 2-dim array and
' transpose them here to get a "flat" 1-dim array of column data
With Application
Slice = .Transpose(.Index(DataArr, 0, colNo))
End With
End Function
警告:对于较大的数据集,分两步重复转换数据可能会很耗时。
Application.Index()
中的 ►array 参数引用的帖子中的基本方法。功能,但首先将一个(例如临时)列插入到物理数据范围,最终通过重新排列包含新添加的额外数据(最后一个位置)的列在任何新位置(例如,在顶部)。
Sub DelSwitchAndInsert()
'Auth: https://stackoverflow.com/users/6460297/t-m
'[0]add other array data as last column to existing range
Sheet1.Range("E1:E4") = Application.Transpose(Array(1, 2, 3, 4))
'[1]get data
Dim data: data = Tabelle7.Range("A1:E4")
'[2]reorder via Array(1, 4, 2), i.e. get 1st column, 4th and 2nd column omitting the 3rd one
data = Application.Index(data, Evaluate("row(1:" & UBound(data) & ")"), Array(UBound(data, 2), 1, 4, 2))
'[3]write to any target
Sheet2.Range("A1").Resize(UBound(data), UBound(data, 2)) = data
End Sub
针对最近评论的解决方法附录 //编辑/2020-07-07
InsCol data, extra, 3 ' insertion e.g. as new 3rd "column"
Sub InsertExtraData()
'Purpose: insert a single-column array (2-dim, 1-based)
'[0]define extra array (or slice AND transpose from other data source)
Dim extra: extra = Application.Transpose(Array(100, 200, 300, 400)) ' example data
'[1]get data (or existing 2-dim array)
Dim data: data = Sheet1.Range("A1:D4")
'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
'[2]insert extra as >>3rd<< column
'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
InsCol data, extra, 3
'[3]write to any target
Sheet2.Range("A1").Resize(UBound(data), UBound(data, 2)) = data
End Sub
Sub InsCol(data, extra, Optional ByVal colNo As Long = 1)
With Sheets.Add
'[0]add data to temporary range
.Range("B1").Resize(UBound(data), UBound(data, 2)) = data
.Range("B1").Offset(0, UBound(data, 2)).Resize(UBound(extra) - LBound(extra) + 1, 1) = extra
'[1]get data
data = .Range("B1").Resize(UBound(data), UBound(data, 2) + 1)
'[2]reorder via Array(5, 1, 2, 3, 4)
data = Application.Index(data, Evaluate("row(1:" & UBound(data) & ")"), getColNums(data, colNo))
'[3]delete temporary sheet
Application.DisplayAlerts = False: .Delete
Application.DisplayAlerts = True
End With
End Sub
Function getColNums(main, Optional ByVal colNo As Long = 1) As Variant()
'c.f. : https://stackoverflow.com/questions/53727578/joining-two-arrays-in-vba/60082345#60082345
'Purp.: return ordinal element counters of combined 0-based 1-dim arrays
Dim i&, n&: n = UBound(main) + 1 ' +1 as one column, +1 from 0-based~>one-based
ReDim tmp(0 To n - 1) ' redim to augmented size (zero-based)
If colNo > n Then colNo = n
If colNo < 1 Then colNo = 1
For i = 0 To colNo - 1: tmp(i) = i + 1: Next i
tmp(colNo - 1) = n
For i = colNo To UBound(tmp): tmp(i) = i: Next i
getColNums = tmp ' return combined elem counters, e.g. Array(1,2, >>5<< ,3,4)
End Function
关于arrays - 将垂直切片插入数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62722676/
我想对齐输入,它有两个标签和一个没有任何标签的按钮,以便它们都在同一级别。 这是期望的效果: 这是我到目前为止得到的: 我通过在按钮前添加带有空白空间的标签,设法让它看起来像我想要的样子,但这并不理想
您好,我有一个关于 JavaFX 的问题。我担心答案是剥皮,我对此一无所知,但这里是。 我想在 JavaFX 中制作 Accordion/TabPane 交叉。我将尝试用文字解释自己,但在下面我已经包
这可能被认为是一个低俗的问题。然而,我还没有找到任何代码,也没有找到任何讨论如何用我的编程语言 C 来解决这个问题的论坛。已经进行了大量的尝试,并且最终都以实际上“硬编码”新数组而告终。 我正在尝试垂
我有以下代码: public Frame() { super(); setVisible(true); setDefaultCloseOperation(JFrame.EXIT
是否可以将 UIModalTransitionStyleFlipHorizontal 修改为垂直而不是水平? 我通常会使用 CATransition 来执行此操作,但该方法需要将一个 UIView
我有一个 ios5 导航的想法,我正在一个应用程序上做,我认为从 SOF 那里得到一些关于我的想法的建设性批评是明智的。 p> 想法: UIView 包含 6 个左右垂直堆叠的按钮 UIButtons
我正在努力进行一些 iOS 开发,我希望有人能够帮助我提出建议。我想实现一堆看起来像一副纸牌的 UIView。用户应该能够通过触摸刷出“卡片”。我想到了带有 pagingEnabled 的 UIScr
我想创建一个包含四张图片的入口页面作为指向其他页面的链接。但我希望这些图片显示在显示器的中间(垂直和水平)。我已经尝试了很多事情,但我做对了。我什至无法以任何方式垂直对齐图片(例如底部,您将在代码中看
我有代码在 div 的底部创建一个元素作为向下的“箭头/指针”。 我需要这样写,以便“箭头/指针”指向左侧 当前代码 - HTML 掩码 css 在 fiddle 中 https://j
下面的代码将焦点放在中间的 div 上,但该 div 出现在窗口的底部。如何使该 div 居中,使其显示在窗口的中心[垂直],而不设置固定位置。 $(function(){ $("#focus
这个问题在这里已经有了答案: Vertical Align Center in Bootstrap 4 [duplicate] (20 个答案) 关闭 4 年前。 我创建了一个由两列组成的结构,第一
演示:http://jsfiddle.net/vpH8r/2/ 我在上面创建了一个 jfiddle,试图让垂直滑动正常工作。 当前的问题是 slider 标签不会移动,并且不会出现从顶部到底部的干净滑
我正在尝试在 javascript 中创建一个垂直 slider 小部件。我不是在寻找任何插件或库,我正在尝试查看如何使用纯 javascript 完成它。我想我大概明白了。 请在此处查看到目前为止已
我正在尝试创建一个响应式导航列表,并将图像置于页面列表的中心 我已经设法接近那个,但是图像比列表更靠前。 我想像这样得到它,但似乎无法弄清楚。 任何帮助将不胜感激! 代码:https://jsfidd
有人可以帮我将导航栏居中,使其在页面上垂直居中吗? 我希望导航栏中央的链接位于顶部,而不是像现在这样向左浮动。 提前致谢 Toggle navigation
我想垂直、水平转换图像,并使用 javascript 缩放图像。目前我设法使调整大小的图像起作用,但它看起来不正确。我正在尝试使用类似于 Transform image 的东西.调整垂直移动条时,图像
这可能是一个问题,但要求太多,但我已经达到了我的极限。 我有这段 ( http://jsfiddle.net/3whTa/) CSS,它创建了一个箭头水平面包屑导航。 我想做的是将其转换为垂直。就像箭
我正在使用 opencv 进行非常简单的操作,但我无法理解为什么会出现此错误/问题。图像被操作到图像的一半(垂直)。 Mat img = imread("/Users/tanmoy/Documents
我想知道是否有人有任何技术来定位 css 生成的内容。例如: .block { height: 150px; width: 150px; border: 1px solid black;
关闭。这个问题需要更多 focused .它目前不接受答案。 想要改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭3年前。 Improve this que
我是一名优秀的程序员,十分优秀!