- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个包含字符串值的数组,我想知道对其进行排序的最佳方法,但我需要将最后一个字符视为数字。
这是一个例子:如果我将值 IRF2BP2K10、IRF2BP2K1 和 IRF2BP2K2 作为数组中的第一个、第二个和第三个元素,我该如何对它们进行排序,以便我的数组可以排列为 {IRF2BP2K1, IRF2BP2K2, IRF2BP2K10} 而不是 {IRF2BP2K1, IRF2BP2K10, IRF2BP2K2} ?
我尝试了下面的基本代码,但最终得到了第二种情况,其中 IRF2BP2K10 在 IRF2BP2K2 之前排序,因为该算法仅考虑字符串:
For currentitem = 1 To lastitem
For nextitem = currentitem + 1 To lastitem
If Array(currentitem) > Array(nextitem) Then
Temp = Array(currentitem)
Array(currentitem) = Array(nextitem)
Array(nextitem) = Temp
End If
Next nextitem
Next currentitem
有人问我,所以这里有更多信息:并非所有项目在数字前都以“K”结尾。
这里是示例的一些其他值,我没有将它们写在数组中,因此更容易可视化:
(this list is the result using my code)
IRF2BP2KICMVCRE1
IRF2BP2KICMVCRE10
IRF2BP2KICMVCRE2
IRF2BP2KIERT2CRE1
IRF2BP2KIERT2CRE10
IRF2BP2KIERT2CRE11
IRF2BP2KIERT2CRE2
IRF2BP2KO1
IRF2BP2KO2
this is what i was trying to get:
IRF2BP2KICMVCRE1
IRF2BP2KICMVCRE2
IRF2BP2KICMVCRE10
IRF2BP2KIERT2CRE1
IRF2BP2KIERT2CRE2
IRF2BP2KIERT2CRE10
IRF2BP2KIERT2CRE11
IRF2BP2KO1
IRF2BP2KO2
我是否需要一种算法来将数组“currentitem”的每个字符串位置与数组“nextitem”的相同位置进行比较?并且,如果它们都相等,则将长度较大的项目放在长度较小的项目之后? [这样我就可以将 IRF2BP2K2 排序在 IRF2BP2K10 之前的位置,因为它们都共享相同的初始字符串“IRF2BP2K”,并且仅在最后一个字符串上有所不同(一个有“2”,另一个有“10”)]
提前致谢!
最佳答案
编辑 GetFormattedArray()
函数以“正确”格式化数组元素最后一位数字
我认为你必须首先正确格式化你的数组元素,然后进行排序
例如,您可以使用以下函数返回一个格式正确的数组
Function GetFormattedArray(originalArray() As String)
ReDim formattedArray(LBound(originalArray) To UBound(originalArray)) As String
ReDim ipos(LBound(originalArray) To UBound(originalArray)) As Long
Dim ielem As Long, iChar As Long, maxChar As Long
Dim strng As String
Const zeros As String = "0000000000"
For ielem = LBound(originalArray) To UBound(originalArray)
strng = originalArray(ielem)
iChar = 1
Do While IsNumeric(Mid(strng, Len(strng) - iChar, 1))
iChar = iChar + 1
Loop
ipos(ielem) = iChar
If iChar > maxChar Then maxChar = iChar
Next
For ielem = LBound(originalArray) To UBound(originalArray)
strng = originalArray(ielem)
formattedArray(ielem) = Left(strng, Len(strng) - ipos(ielem)) & Format(Right(strng, ipos(ielem)), Left(zeros, maxChar))
Next
GetFormattedArray = formattedArray
End Function
你的“main”可以利用如下:
Sub main()
Dim myArray(1 To 3) As String, myFormattedArray() As String
Dim currentItem As Long, nextItem As Long, lastItem As Long
Dim tempStrng As String
myArray(1) = "IRF2BP2K10"
myArray(2) = "IRF2BP2K1"
myArray(3) = "IRF2BP2K2"
myFormattedArray = GetFormattedArray(myArray)
lastItem = UBound(myFormattedArray)
For currentItem = LBound(myArray) To lastItem
For nextItem = currentItem + 1 To lastItem
If myFormattedArray(currentItem) > myFormattedArray(nextItem) Then
tempStrng = myFormattedArray(currentItem)
myFormattedArray(currentItem) = myFormattedArray(nextItem)
myFormattedArray(nextItem) = tempStrng
End If
Next nextItem
Next currentItem
End Sub
关于excel - 在 excel vba 中,将最后一个字符视为数字,对字符串进行排序的最佳方法是什么,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41578801/
fiddle :http://jsfiddle.net/rtucgv74/ 我正在尝试将第一个字符与 3 位数字匹配。所以下面的代码应该提醒f234。但反而返回 null ? 源代码: var reg
复制代码 代码如下: Dim strOk,strNo strOk = "12312321$12
我想找 {a number} / { a number } / {a string}模式。我可以得到number / number工作,但是当我添加 / string它不是。 我试图找到的例子: 15
我,我正在做一个模式正则表达式来检查字符串是否是: 数字.数字.数字,如下所示: 1.1.1 0.20.2 58.55541.5221 在java中我使用这个: private static Patt
我有一个字符串,我需要检查它是否在字符串的末尾包含一个数字/数字,并且需要将该数字/数字递增到字符串末尾 +1 我会得到下面的字符串 string2 = suppose_name_1 string3
我正在寻找一个正则表达式 (数字/数字),如(1/2) 数字必须是 1-3 位数字。我使用 Java。 我认为我的问题比正则表达式更深。我无法让这个工作 String s ="(1/15)";
谁能帮我理解为什么我在使用以下代码时会出现类型错误: function sumOfTwoNumbersInArray(a: [number, number]) { return a[0] +
我看到有些人过去也遇到过类似的问题,但他们似乎只是不同,所以解决方案也有所不同。所以这里是: 我正在尝试在 Google Apps 脚本中返回工作表的已知尺寸范围,如下所示: var myRange
我试图了解python中的正则表达式模块。我试图让我的程序从用户输入的一行文本中匹配以下模式: 8-13 之间的数字“/” 0-15 之间的数字 例如:8/2、11/13、10/9 等。 我想出的模式
简单地说,我当前正在开发的程序要求我拆分扫描仪输入(例如:2 个火腿和奶酪 5.5)。它应该读取杂货订单并将其分成三个数组。我应该使用 string.split 并能够将此输入分成三部分,而不管中间字
(number) & (-number) 是什么意思?我已经搜索过了,但无法找到含义 我想在 for 循环中使用 i & (-i),例如: for (i = 0; i 110000 .对于i没有高于
需要将图像ID设置为数字 var number = $(this).attr('rel'); number = parseInt(number); $('#carousel .slid
我有一个函数,我想确保它接受一个字符串,后跟一个数字。并且可选地,更多的字符串数字对。就像一个元组,但“无限”次: const fn = (...args: [string, number] | [s
我想复制“可用”输入数字的更改并将其添加或减去到“总计”中 如果此人将“可用”更改为“3”,则“总计”将变为“9”。 如果用户将“可用”更改为“5”,则“总计”将变为“11”。 $('#id1').b
我有一个与 R 中的断线相关的简单问题。 我正在尝试粘贴,但在获取(字符/数字)之间的断线时遇到问题。请注意,这些值包含在向量中(V1=81,V2=55,V3=25)我已经尝试过这段代码: cat(p
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我在 Typescript 中收到以下错误: Argument of type 'number[]' is not assignable to parameter of type 'number' 我
在本教程中,您将通过示例了解JavaScript 数字。 在JavaScript中,数字是基本数据类型。例如, const a = 3; const b = 3.13; 与其他一些编程语言不同
我在 MDN Reintroduction to JavaScript 上阅读JavaScript 数字只是浮点精度类型,JavaScript 中没有整数。然而 JavaScript 有两个函数,pa
我们在 Excel 中管理库存。我知道这有点过时,但我们正在发展商业公司,我们所有的钱都被困在业务上,没有钱投资 IT。 所以我想知道我可以用Excel自动完成产品编号的方式进行编程吗? 这是一个产品
我是一名优秀的程序员,十分优秀!