今天突然发现个问题,系统升级win10后,原来正常使用的软件报错:【该字符串未被识别为有效的 DateTime。有一个从索引 11 处开始的未知字。】
经过排查发现是升级后系统的时间自动变成了长时间,导致筛选字符串出错。
因为不可能让所有用户出现问题的时候都去修改时间设置,请问在代码中如何设置,可以强制将系统长时间转换成短时间,避免受到系统的干扰?

此主题相关图片如下:2016年1月19日1.png


此主题相关图片如下:2016年1月19日2.png


此主题相关图片如下:2016年1月19日3.png


此主题相关图片如下:2016年1月19日4.png

以下是我的筛选树代码:
Dim Filter As String = ""
If e.node.Name <> "显示所有记录" Then
Dim d1 As Date
Dim d2 As Date
Dim Year As Integer = e.Node.DataRow("年")
Dim Quarter As Integer = e.Node.DataRow("季度")
Dim Product As String = e.Node.DataRow("部门")
Select Case e.Node.Level
Case 0
d1 = New Date(Year,1,1) '取得该年的第一天
d2 = new Date(Year,12,31) '取得该年的最后一天
d1 = Format(d1,"yyyy-MM-dd")
d2 = Format(d2,"yyyy-MM-dd")
msgbox(d1)
Filter = "日期 >= #" & d1 & "# And 日期 <= #" & d2 & "#"
Case 1
d1 = New Date(Year, 3 * (Quarter - 1) + 1, 1) '获取该季度的第一天
d2 = New Date(Year, 3 * Quarter, Date.DaysInMonth(Year,3 * Quarter)) '获取该季度的最后一天
Filter = "日期 >= #" & d1 & "# And 日期 <= #" & d2 & "#"
Case 2
d1 = New Date(Year, 3 * (Quarter - 1) + 1, 1) '获取该季度的第一天
d2 = New Date(Year, 3 * Quarter, Date.DaysInMonth(Year,3 * Quarter)) '获取该季度的最后一天
Filter = "日期 >= #" & d1 & "# And 日期 <= #" & d2 & "# And 部门 = '" & Product & "'"
End Select
Tables("外宣信息记录").Filter = Filter
msgbox(filter)
Else
Tables("外宣信息记录").Filter = ""
End If
[此贴子已经被作者于2016/1/19 14:52:31编辑过]