[已解决]查找文件内容返回关键字除外特定列字符串重复所有行的内容
本帖最后由 fuinei 于 2012-8-2 14:07 编辑各位好,请问如何可以实现查找文件所有内容后返回关键字除外特定列字符串重复所有行的内容呢?
文件如:
PC1 192.168.1.1 unknown
PC2 192.168.1.2 s1-123434
PC3 192.168.1.3 S1-1235u7
PC4 192.168.1.4 S1-343244
PC5 192.168.1.5 S1-123434
PC6 192.168.1.6 S1-343244
如果把unknown设置为排除关键字查找第3列内容重复的行,我希望可以返回以下内容:
PC2 192.168.1.2 s1-123434
PC4 192.168.1.4 S1-343244
PC5 192.168.1.5 S1-123434
PC6 192.168.1.6 S1-343244 S1-1235u7 这行也不包括unknown,也排除了? 回复 2# xiaowo
PC3 192.168.1.3 S1-1235u7 这行排除,因为其它的行没有再出现S1-1235u7 回复 3# fuinei
_filereadtoarray()
_arrayfindall()
for
。。。。。
next
或者正则 本帖最后由 fuinei 于 2012-7-31 15:10 编辑
回复 4# netegg
谢谢netegg元老的指导,根据指导成功把结果读入数组和初步找出指定例(范例中ID列)相同的行号,但折腾了大半天未能实现最终的目标(把ID列相同行的信息写入到result.xls文件中),以下是我的代码,希望各位可以再指导一下,谢谢!
#include <File.au3>
#include <Array.au3>
Local $Detailinfo,$LineDetailinfoi,$LineDetailinfoj,$Duplicateinfo
Local $list = @ScriptDir & "\info.txt"
$Result_log = @ScriptDir & "\result.xls"
If FileExists($list) = 1 then
If _FileReadToArray($list,$Detailinfo) = 0 Then
MsgBox(48,"Error","读取数据文件失败,程序将退出!")
Exit
EndIf
Else
MsgBox(48,"Error","无法找到数据文件,程序将退出!")
Exit
EndIf
$file = FileOpen($Result_log,1)
If $file = -1 Then
MsgBox(48,"Error","无法打开日志文件,程序将退出!")
Exit
EndIf
FileWrite($file,"ComputerName" & @TAB & "IP_Address" & @TAB & "ID" & @TAB & "Remark"& @CRLF)
FileClose($file)
For $i = 1 To $Detailinfo
If StringInStr($Detailinfo[$i],"unknown") > 0 Then
ContinueLoop
EndIf
$LineDetailinfoi = StringSplit($Detailinfo[$i],@TAB)
If $LineDetailinfoi = "" then
ContinueLoop
EndIf
Local $Duplicateinfo = _ArrayFindAll($Detailinfo,$LineDetailinfoi,0,0,0,1)
_ArrayDisplay($Duplicateinfo)
;.....剩余部分未完成
Next
MsgBox(0,"Info","程序已运行完成,请查看日志!")
ComputerName IP_Address ID Remark
PC01 192.168.1.100 unknown network connection fail
PC02 192.168.1.101
PC03 192.168.1.102 d5199328-a0a2-4d7a-b34e-b46d0911a7f2
PC04 192.168.1.103 379a6577-aa4b-4066-9d17-2d00fa397234
PC05 192.168.1.104 15acb015-4a85-4198-bf3b-f64d1935e5cb
PC06 192.168.1.105 4796fa0a-5586-415c-a320-635b295c9e78
PC07 192.168.1.106 unknown network connection fail
PC08 192.168.1.107 0d030885-daa7-43b8-97d7-2ff60a700571
PC09 192.168.1.108 unknown network connection fail
PC10 192.168.1.109
PC11 192.168.1.110 unknown network connection fail
PC12 192.168.1.111 e6b413f1-2ca9-4bd9-b671-ca265f893406
PC13 192.168.1.112
PC14 192.168.1.113 9f8f7940-189e-439a-b8e8-e13785843570
PC15 192.168.1.114 unknown network connection fail
PC16 192.168.1.115 2b759e67-0691-4062-891e-2d3238d92201
PC17 192.168.1.116 45c3d1de-864f-4f01-81a2-242919e6f9e1
PC18 192.168.1.117 unknown network connection fail
PC19 192.168.1.118 208b5299-b099-43fe-b398-b2d95c16c324
PC20 192.168.1.119
PC21 192.168.1.120 e2c29470-fa68-4192-86fa-96232b2bba86
PC22 192.168.1.121 042166a9-20c5-4d82-900a-6156c61131cf
PC23 192.168.1.122 0be61cd7-7d57-4188-bc66-f4d4e924931c
PC24 192.168.1.123 c86b0785-2022-4a05-bd41-f7362cf2e452
PC25 192.168.1.124 unknown network connection fail
PC26 192.168.1.125 bb7244fb-6875-4e8e-9a09-e24a7e0b9bd1
PC27 192.168.1.126 f025c7c0-7156-4c31-bc7e-db1683b8cee8
PC28 192.168.1.127 379a6577-aa4b-4066-9d17-2d00fa397234
PC29 192.168.1.128 e7b3fa28-ac14-4102-82b7-b5744e4dc9a8
PC30 192.168.1.129 75c81087-003d-4c61-b016-3f62e51e2fde
PC31 192.168.1.130 unknown network connection fail
PC32 192.168.1.131 unknown network connection fail
PC33 192.168.1.132 unknown network connection fail
PC34 192.168.1.133 unknown network connection fail
PC35 192.168.1.134 f1c13063-7550-4ef1-9e88-f31d512345da
PC36 192.168.1.135 379a6577-aa4b-4066-9d17-2d00fa397234
PC37 192.168.1.136 unknown network connection fail
PC38 192.168.1.137 249bee6f-b061-44c7-a14c-884076df3dff
附件为info.txt 本帖最后由 afan 于 2012-7-31 20:29 编辑
不用管“unknown”,直接取需要的“xxx-xxx-xxx-xxx-xxxxxxx”Local $list = @ScriptDir & '\info.txt'
Local $Result_log = @ScriptDir & '\result.xls'
Local $sOut = 'ComputerName' & @TAB & 'IP_Address' & @TAB & 'ID' & @TAB & 'Remark' & @CRLF
Local $aSR = StringRegExp(FileRead($list), '(?m)(.*?(\H+)(?=\t\r?$))', 3)
If @error Then Exit MsgBox(48, '', '错误')
For $i = 1 To UBound($aSR) - 1 Step 2
If IsDeclared($aSR[$i]) Then
$sOut &= Eval($aSR[$i]) & $aSR[$i - 1] & @CRLF
Assign($aSR[$i], '')
Else
Assign($aSR[$i], $aSR[$i - 1] & @CRLF)
EndIf
Next
FileWrite($Result_log, $sOut)
MsgBox(0, 'Info', '程序已运行完成,请查看日志!')正则在效率及代码简洁度上很占优势 回复 6# afan
谢谢afan版主的指导,程序测试成功! 正则确实非常方便但比较深奥,对于数组的方式希望有高手可以继续指点一下,谢谢! 回复 7# fuinei
afan写过一个排除关键字的udf,也可以直接用,udf区里有 #include <array.au3>
Local $out=""
Local $str=FileRead("info.txt")
Local $Test = StringRegExp($str, '(.{8}-.{4}-.{4}-.{4}-.{12})(?=(?:[^\1]+\1))', 3)
$Test1=_ArrayUnique($Test)
$ex='(.*?('&_ArrayToString($Test1,"|",1)&'))'
$aa=StringRegExp($str,$ex,3)
For $i=0 to UBound($aa)-1 Step 2
$out&=$aa[$i]&@CRLF
Next
MsgBox(0,0,$out) 回复 9# netegg
谢谢netegg元老的指导,我没找到能否给出具体的标题名称或Link呢? 回复 10# 3mile
谢谢指导,对于正则目前还不能理解,看来要学习一下了 本帖最后由 netegg 于 2012-8-1 11:57 编辑
回复 11# fuinei
http://www.autoitx.com/thread-11801-1-2.html 回复 13# netegg
谢谢netegg元老的指导!
页:
[1]