- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我创建了一个宏 Excel 文件来对一些数据进行排序并做一些 Vlookup
具有相同数据的功能。
该宏在我的系统中运行良好。我与同事共享的同一宏也使用相同的数据集,但最终结果不正确,或与我的结果不匹配。
请问我们如何解决这个问题?
数据集相当大。那里有将近 200k 行。
他们没有收到任何错误。宏正在运行完整的代码,系统也没有任何错误,但最终报告不匹配或不正确。
不匹配仅出现在日期区域。有日期列mm/dd/yyyy
格式化为文本。
我曾经将此文本格式的日期转换为日期,然后我必须从列中删除所有 future 的日期。
仅此功能对其他人无法正常工作。其余部分都清楚了。但这在我的系统中运行良好。
下面是我用来将文本日期转换为数字日期并删除 future 日期然后将可用日期更改为旧格式的代码
Private Sub TermDateRemove()
Dim CellValue, OldFrmtDate As String
Dim y, Tday As Date
Dim EmpTerDate As Range
Dim EmpTerDatePos As Integer
Sheets("Emp Data").Activate
LR = Worksheets("Emp Data").UsedRange.Rows.count
LC = Worksheets("Emp Data").UsedRange.Columns.count
If ActiveSheet.AutoFilterMode = True Then
ActiveSheet.AutoFilterMode = False
End If
Set EmpTerDate = Sheets("Emp Data").Range("1:1").Find("Employee Termination Date", , xlValues, xlWhole, , , False, , False)
EmpTerDatePos = EmpTerDate.Column
txt2clm (EmpTerDatePos) 'Calling text to column function
Tday = Format(Date, "dd/mm/yy")
With Worksheets("Emp Data")
.Range("1:1").AutoFilter Field:=EmpTerDatePos, Criteria1:=">" & Tday, Operator:=xlFilterValues
End With
If ActiveSheet.AutoFilter.Range.Columns(1).SpecialCells(xlCellTypeVisible).count > 1 Then
With Worksheets("Emp Data")
.Range(.Cells(2, EmpTerDatePos), .Cells(LR, EmpTerDatePos)).SpecialCells(xlCellTypeVisible).Cells.Value = ""
End With
End If
If ActiveSheet.AutoFilterMode = True Then
ActiveSheet.AutoFilterMode = False
End If
Columns(EmpTerDatePos).NumberFormat = "@"
For Each cell In Sheets("EMP DATA").UsedRange.Columns(EmpTerDatePos).Cells
CellValue = cell.Value
If CellValue = "Employee Termination Date" Then
'do nothing
ElseIf CellValue <> "" And CellValue <> "Employee Termination Date" Then
CVtoDate = Format(CellValue, "mm/dd/yyyy")
OldFrmtDate = Replace(CVtoDate, "-", "/")
cell.Value = OldFrmtDate
End If
Next
Workbooks("Employee Data").Save
End Sub
- - -功能 - - -
Function txt2clm(cc As Long) As Long
'Text to column for changing the date into numeric format
Columns(cc).Select
Selection.TextToColumns Destination:=Range(ActiveSheet.Cells(1, cc), ActiveSheet.Cells(1, cc)), DataType:=xlDelimited, _
TextQualifier:=xlDoubleQuote, ConsecutiveDelimiter:=False, Tab:=False, _
Semicolon:=False, Comma:=False, Space:=False, Other:=False, FieldInfo _
:=Array(1, 3), TrailingMinusNumbers:=True
End Function
最佳答案
转换 String
(看起来像约会)dd/mm/yy
通过 /
将其拆分为多个部分,将其转换为实数/数字日期并使用 DateSerial
.
Dim Cell As Range
For Each cell In Sheets("Emp Data").UsedRange.Columns(EmpTerDatePos).Cells
Dim CellValue As String
CellValue = cell.Value
If CellValue <> vbNullString And CellValue <> "Employee Termination Date" Then
Dim SplitDate As String
SplitDate = Split(CellValue, "/")
Dim DayFromDate As Integer
DayFromDate = CInt(SplitDate(1))
Dim MonthFromDate As Integer
MonthFromDate = CInt(SplitDate(0))
Dim YearFromDate As Integer
YearFromDate = CInt(SplitDate(2))
Dim NumDate As Date
NumDate = DateSerial(YearFromDate, MonthFromDate, DayFromDate)
cell.Value = NumDate
End If
Next
还要确保你不使用
String
作为过滤条件,这可能会再次在其他计算机上失败。切勿使用
Strings
日期。
Dim Tday As Date
Format
函数返回
String
然后隐式转换为数字
Date
变量
Tday = Format(Date, "dd/mm/yy")
.这意味着 Excel 必须猜测
String
来自
Format
函数是
dd/mm/yy
或
mm/dd/yy
.即使您指定了,VBA 也不够聪明,无法使用该信息来解释该字符串。
Dim Tday As Date
Tday = Date
With Worksheets("Emp Data")
.Range("1:1").AutoFilter Field:=EmpTerDatePos, Criteria1:=">" & CDbl(Tday), Operator:=xlFilterValues
End With
这里我们转换日期
Tday
变成
Double
使用
CDbl(Tday)
.所有数字日期/时间都由
Double
类型的数字表示.因此我们使用
Double
作为标准。这与您的代码一样可靠得多,并且适用于任何县本地化。
ActiveSheet
以及像
Worksheets("Emp Data")
这样的显式引用因此,当您的工作表未激活时,代码甚至可以工作。
关于excel - 将文本转换为日期适用于一个系统,但不适用于其他系统,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/70951411/
我有这个代码: System.err.print("number of terms = "); System.out.println(allTerms.size()); System.err
我有以下问题:在操作系统是 Linux 的情况下和在操作系统是 MacOs 的情况下,我必须执行不同的操作。 所以我创建了以下 Ant 脚本目标: /u
我正在调用 system("bash ../tools/bashScript\"This is an argument!\"&"),然后我正在调用 close(socketFD) 直接在 system
使用最初生成的随机元素来约束随机数组的连续元素是否有效。 例如:我想生成一组 10 个 addr、size 对来模拟典型的内存分配例程并具有如下类: class abc; rand bit[5:0
我正在创建一个必须使用system(const char*)函数来完成一些“繁重工作”的应用程序,并且我需要能够为用户提供粗略的进度百分比。例如,如果操作系统正在为您移动文件,它会为您提供一个进度条,
我即将编写一些项目经理、开发人员和业务分析师会使用的标准/指南和模板。目标是更好地理解正在开发或已经开发的解决方案。 其中一部分是提供有关记录解决方案的标准/指南。例如。记录解决/满足业务案例/用户需
在开发使用压缩磁盘索引或磁盘文件的应用程序时,其中部分索引或文件被重复访问(为了论证,让我们说一些类似于 Zipfian 分布的东西),我想知道什么时候足够/更好地依赖操作系统级缓存(例如,Debia
我们编写了一个 powershell 脚本,用于处理来自内部系统的图像并将其发送到另一个系统。现在,业务的另一部分希望加入其中,对数据进行自己的处理,并将其推送到另一个系统。打听了一下,公司周围有几个
我正在尝试朗姆酒我的应用程序,但我收到以下错误:System.Web.HttpUnhandledException:引发了“System.Web.HttpUnhandledException”类型的异
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
所以我在其他程序中没有收到此错误,但我在这个程序中收到了它。 这个程序是一个我没有收到错误的示例。 #include int main() { system("pause"); } // en
我在 c# System.URI.FormatExption 中遇到问题 为了清楚起见,我使用的是 Segseuil 的 Matlab 方法,并且它返回一个图片路径 result。我想为其他用户保存此
我正在尝试像这样设置文本框的背景色: txtCompanyName.BackColor = Drawing.Color.WhiteSmoke; 它不喜欢它,因为它要我在前面添加系统,例如: txtCo
请帮助我解决 System.StackOverflowException我想用 .aspx 将记录写入数据库我使用 4 层架构来实现这一切都正常但是当我编译页面然后它显示要插入数据的字段时,当我将数据
我使用了一些通常由系统调用的API。 因此,我将 android:sharedUserId="android.uid.system" 添加到 manifest.xml, 并使用来自 GIT 的 And
我正在尝试创建一个小型应用程序,它需要对/system 文件夹进行读/写访问(它正在尝试删除一个文件,并创建一个新文件来代替它)。我可以使用 adb 毫无问题地重新挂载该文件夹,如果我这样做,我的应用
我想从没有 su 的系统 priv-app 将/system 重新挂载为 RW。如何以编程方式执行此操作?只会用 Runtime.getruntime().exec() 执行一个 shell 命令吗
我正在尝试制作一个带有登录系统的程序我对此很陌生,但我已经连续工作 8 个小时试图解决这个问题。这是我得到的错误代码 + ServerVersion 'con.ServerVersion' threw
当我“构建并运行”Code::Blocks 中的程序时,它运行得非常好!但是当我从“/bin”文件夹手动运行它时,当它试图用 system() 调用“temp.bat”时,它会重置。这是为什么?它没有
我想使用 system/pipe 命令来执行具有特殊字符的命令。下面是示例代码。通过系统/管道执行命令后,它通过改变特殊字符来改变命令。我很惊讶地看到系统命令正在更改作为命令传递的文本。 run(ch
我是一名优秀的程序员,十分优秀!