以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  时间问题,当年的时间如何设置  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=160184)

--  作者:hbfnmxb
--  发布时间:2021/1/23 19:17:00
--  时间问题,当年的时间如何设置
这里有一段代码:

Dim dt1 As DataTable = DataTables("一分一档")
For Each ary As String() In dt1.GetValues("选科系列|最低分", "选科系列 is not null")
    Dim filter As String = "选科系列=\'" & ary(0) & "\'And 最低分=\'" & ary(1) & "\'"
    Dim filter1 As String = filter & " And 录取年度 = \'2021\'"
    Dim filter2 As String = filter & " And 录取年度 = \'2020\'"
    Dim filter3 As String = filter & " And 录取年度 = \'2019\'"
    Dim filter4 As String = filter & " And 录取年度 = \'2018\'"
    Dim filter5 As String = filter & " And 录取年度 = \'2017\'"

Dim fdr1 = dt1.find(filter1)
    If fdr1 IsNot Nothing Then
        dt1.ReplaceFor("本年度排名", fdr1("全省排名"), filter)
    End If
    
    Dim fdr2 = dt1.find(filter2)
    If fdr2 IsNot Nothing Then
        dt1.ReplaceFor("减一年排名", fdr2("全省排名"), filter)
    End If
    
    Dim fdr3 = dt1.find(filter3)
    If fdr3 IsNot Nothing Then
        dt1.ReplaceFor("减二年排名", fdr3("全省排名"), filter)
    End If
    
    Dim fdr4 = dt1.find(filter4)
    If fdr4 IsNot Nothing Then
        dt1.ReplaceFor("减三年排名", fdr4("全省排名"), filter)
    End If

    Dim fdr5 = dt1.find(filter5)
    If fdr5 IsNot Nothing Then
        dt1.ReplaceFor("减四年排名", fdr5("全省排名"), filter)
    End If

Next
红色部分中的2021年、2020年、2019年,我希望用Year(today())这种变量格式来表示。目的就是代码设置好后,到明年甚至后年也就是2022年或2023年不再去改动它。这段代码如何修改?谢谢老师

--  作者:李孝春
--  发布时间:2021/1/23 21:07:00
--  回复:(hbfnmxb)时间问题,当年的时间如何设置
Dim t As Date= Date.Now
For Each ary As String() In dt1.GetValues("选科系列|最低分", "选科系列 is not null")
    Dim filter As String = "选科系列=\'" & ary(0) & "\'And 最低分=\'" & ary(1) & "\'"
    Dim filter1 As String = filter & " And 录取年度 = \'" & t.Year & "\'"

是不是这样的?

--  作者:hbfnmxb
--  发布时间:2021/1/23 21:32:00
--  
谢谢老师!2020年,2019年如何定义呢?


--  作者:李孝春
--  发布时间:2021/1/23 21:35:00
--  回复:(hbfnmxb)谢谢老师!2020年,2019年如何定义呢...
你是要当年时间然后对应倒退几年?

Dim d1 As Date = d.AddYears(10\'加上10年
Dim
 d2 
As Date = d.AddYears(-10\'减去10年


Dim t As Date= Date.Now
For Each ary As String() In dt1.GetValues("选科系列|最低分", "选科系列 is not null")
Dim filter As String = "选科系列=\'" & ary(0) & "\'And 最低分=\'" & ary(1) & "\'"
Dim i As Integer
For i = 0 To 4   ‘从当年开始倒退五年
    Dim d2 As Date = t.AddYears(-i) \'减去年
    Dim filter1 As String = filter & " And 录取年度 = \'" & d2.year & "\'"
Next
[此贴子已经被作者于2021/1/23 21:50:50编辑过]

--  作者:hbfnmxb
--  发布时间:2021/1/23 21:53:00
--  
当年2021年,需要这个时间,减一年2020年,这个时间也需要,2019年,减二年的,2018年减三年的,还有2017年,减四年。红色代码部分的年度,都需要修改成变量
--  作者:hbfnmxb
--  发布时间:2021/1/23 22:07:00
--  
无法在 System.Double 和 System.String 上执行“=”操作
这个错误提示是什么原因?哪里出了问题?

--  作者:hbfnmxb
--  发布时间:2021/1/23 22:28:00
--  
Dim t As Date= Date.Now
Dim t1 As Date = t.AddYears(-1\'减去1年,即2020年
Dim t2 As Date = t.AddYears(-2\'减去2年,即2019年
Dim t3 As Date = t.AddYears(-3\'减去3年,即2018年
Dim t4 As Date = t.AddYears(-4\'减去4年,即2017年
Dim dt1 As DataTable = DataTables("一分一档")
For Each ary As String() In dt1.GetValues("选科系列|最低分", "选科系列 is not null")
    Dim filter As String = "选科系列=\'" & ary(0) & "\'And 最低分=\'" & ary(1) & "\'"
    Dim filter1 As String = filter & " And 录取年度 = \'" & t.Year & "\'"
    Dim filter2 As String = filter & " And 录取年度 = \'" & t1.Year & "\'"
    Dim filter3 As String = filter & " And 录取年度 = \'" & t2.Year & "\'"
    Dim filter4 As String = filter & " And 录取年度 = \'" & t3.Year & "\'"
    Dim filter5 As String = filter & " And 录取年度 = \'" & t4.Year & "\'"

Dim fdr1 = dt1.find(filter1)
    If fdr1 IsNot Nothing Then
        dt1.ReplaceFor("本年度排名", fdr1("全省排名"), filter)
    End If
    
    Dim fdr2 = dt1.find(filter2)
    If fdr2 IsNot Nothing Then
        dt1.ReplaceFor("减一年排名", fdr2("全省排名"), filter)
    End If
    
    Dim fdr3 = dt1.find(filter3)
    If fdr3 IsNot Nothing Then
        dt1.ReplaceFor("减二年排名", fdr3("全省排名"), filter)
    End If
    
    Dim fdr4 = dt1.find(filter4)
    If fdr4 IsNot Nothing Then
        dt1.ReplaceFor("减三年排名", fdr4("全省排名"), filter)
    End If

    Dim fdr5 = dt1.find(filter5)
    If fdr5 IsNot Nothing Then
        dt1.ReplaceFor("减四年排名", fdr5("全省排名"), filter)
    End If

Next

嗯,红色部分代码,这样修改应该可以,老师看一下。对吗?

--  作者:李孝春
--  发布时间:2021/1/23 22:30:00
--  回复:(hbfnmxb)无法在 System.Double 和 System.St...
Dim t As Date= Date.Now
\'For Each ary As String() In dt1.GetValues("选科系列|最低分", "选科系列 is not null")
\'Dim filter As String = "选科系列=\'" & ary(0) & "\'And 最低分=\'" & ary(1) & "\'"
Dim i As Integer
For i = 0 To 4   \'从当年开始倒退五年
    Dim d2 As Date = t.AddYears(-i) \'减去年
    Dim filter As String ="ABC"
    Dim filter1 As String = filter & " And 录取年度 = \'" & d2.year & "\'"
    output.Show(filter1 )
Next
上面代码在命令创库运行
得到结果
ABC And 录取年度 = \'2021\'
ABC And 录取年度 = \'2020\'
ABC And 录取年度 = \'2019\'
ABC And 录取年度 = \'2018\'
ABC And 录取年度 = \'2017\'

请自行排查一下 你其他代码

你代码标注的红色部分 换成下面的代码试一试
Dim i As Integer
For i = 0 To 4   \'从当年开始倒退五年
    Dim d2 As Date = t.AddYears(-i) \'减去年
    Dim filter1 As String = filter & " And 录取年度 = \'" & d2.year & "\'"
    output.Show(filter1 )
Next
[此贴子已经被作者于2021/1/23 22:31:16编辑过]

--  作者:hbfnmxb
--  发布时间:2021/1/23 22:33:00
--  
好的,谢谢老师。我再查一查