我在这里为你写了一个小脚本。启动ReFormat()来创建新表。它读取活动工作表中的当前数据并将其放入数组中。然后,我从G1开始在同一张表格中创建新表格。
请给我一个反馈,这是一个工作。 (如果它为你工作,接受答案就好)。
Option Explicit
Dim DataArray() As String
Dim lngRow As Long, lngLastRow As Long
Dim intColumn As Integer
Sub ReFormat()
Dim ResultTable As Range
Dim CurrentResultRow As Long
Dim i As Long
FillSourceArray
Set ResultTable = ActiveSheet.Range("G1")
CurrentResultRow = 0
ResultTable.Offset(CurrentResultRow, 0).Value = "Date"
ResultTable.Offset(CurrentResultRow, 1).Value = "user"
ResultTable.Offset(CurrentResultRow, 2).Value = "Logged into"
ResultTable.Offset(CurrentResultRow, 3).Value = "Logged out"
ResultTable.Offset(CurrentResultRow, 4).Value = "Domain"
ResultTable.Offset(CurrentResultRow, 5).Value = "Country"
CurrentResultRow = CurrentResultRow + 1
For i = 1 To lngLastRow - 1
If (DataArray(i, 3) = "loggedinto") Then
ResultTable.Offset(CurrentResultRow, 0).Value = DataArray(i, 0)
ResultTable.Offset(CurrentResultRow, 1).Value = DataArray(i, 1)
ResultTable.Offset(CurrentResultRow, 2).Value = DataArray(i, 2)
ResultTable.Offset(CurrentResultRow, 3).Value = SearchLogOut(DataArray(i, 1), i + 1)
ResultTable.Offset(CurrentResultRow, 4).Value = DataArray(i, 4)
ResultTable.Offset(CurrentResultRow, 5).Value = SearchCountry(DataArray(i, 4))
CurrentResultRow = CurrentResultRow + 1
End If
Next i
End Sub
Function SearchLogOut(user As String, Start As Integer) As String
Dim i As Long
For i = Start To lngLastRow - 1
If ((DataArray(i, 1) = user) And (DataArray(i, 3) = "loggedout")) Then
SearchLogOut = DataArray(i, 2)
Exit For
ElseIf ((DataArray(i, 1) = user) And (DataArray(i, 3) = "loggedinto")) Then
SearchLogOut = ""
Exit For
End If
Next i
End Function
Function SearchCountry(Country As String) As String
Select Case Country
Case "A"
SearchCountry = "India"
Case "B"
SearchCountry = "China"
End Select
End Function
Sub FillSourceArray()
'Read the Source Data
lngLastRow = Cells(Rows.Count, 1).End(xlUp).Row
ReDim DataArray(lngLastRow - 1, 4)
For lngRow = 1 To lngLastRow
For intColumn = 1 To 5
DataArray(lngRow - 1, intColumn - 1) = Cells(lngRow, intColumn)
Next intColumn
Next lngRow
End Sub
也许你可以试试DTS !!。 – varadarajan 2011-05-02 13:47:47
您必须使用VBA,特别是处理用户在同一个域上登录两次而不登出的情况。你的例子的第3和第4行。你想在这种情况下得到什么结果? – 2011-05-02 15:16:49
@corbett:然后让退出时间字段为空的那些records.but但我需要这种格式反正。 – aln 2011-05-02 18:16:55