vb怎样删除txt文本文件中有“非数字字符”的行?
vb程序安装目录下的子文件夹abc中有一些以txt为扩展名的文本文件,这些文件mulitiline属性都是true。这些文件中主要是一些分行排列的数字,但也有一些不是数字...
vb程序安装目录下的子文件夹abc中有一些以txt为扩展名的文本文件,这些文件mulitiline属性都是true。这些文件中主要是一些分行排列的数字,但也有一些不是数字的字符混进来(比如:11个;2011年)。点击窗体上按钮command1后,自动删除这些文本文件中非数字字符的行(当然要连同这些行中的数字都删除)。并且不留空行。
点击command1时要生成一个文本文本,最好在这时就检测文本中是否有非数字字符的行,并且删除。这是上策。。 展开
点击command1时要生成一个文本文本,最好在这时就检测文本中是否有非数字字符的行,并且删除。这是上策。。 展开
8个回答
展开全部
'添加一个filelistbox,一个commandbutton
Private Sub Command1_Click()
Dim i As Integer
If Dir(App.Path & "\abc", vbDirectory) = "" Then MsgBox "没有“" & App.Path & "\abc" & "”文件夹": Exit Sub
File1.Path = App.Path & "\abc"
For i = 0 To File1.ListCount - 1
File1.ListIndex = i
If Right(File1.FileName, 3) = "txt" Then zhzsucyg (App.Path & "\abc\" & File1.FileName)
Next
End Sub
Private Function zhzsucyg(myFile As String)
Dim myLine() As String, myTemp As String, myOK As Boolean, myOutput As String, i As Integer, j As Integer
Open myFile For Binary As #1
myLine = Split(Input(LOF(1), 1), vbCrLf)
Close
For i = 0 To UBound(myLine)
myTemp = myLine(i)
For j = 0 To 9
myTemp = Replace(myTemp, CStr(j), "")
Next
If myTemp = "" Then myOutput = myOutput & myLine(i) & vbCrLf: myOK = True
Next
If myOK = True Then
Open myFile For Output As #1
Print #1, myOutput
Close
myOK = False
End If
End Function
Private Sub Command1_Click()
Dim i As Integer
If Dir(App.Path & "\abc", vbDirectory) = "" Then MsgBox "没有“" & App.Path & "\abc" & "”文件夹": Exit Sub
File1.Path = App.Path & "\abc"
For i = 0 To File1.ListCount - 1
File1.ListIndex = i
If Right(File1.FileName, 3) = "txt" Then zhzsucyg (App.Path & "\abc\" & File1.FileName)
Next
End Sub
Private Function zhzsucyg(myFile As String)
Dim myLine() As String, myTemp As String, myOK As Boolean, myOutput As String, i As Integer, j As Integer
Open myFile For Binary As #1
myLine = Split(Input(LOF(1), 1), vbCrLf)
Close
For i = 0 To UBound(myLine)
myTemp = myLine(i)
For j = 0 To 9
myTemp = Replace(myTemp, CStr(j), "")
Next
If myTemp = "" Then myOutput = myOutput & myLine(i) & vbCrLf: myOK = True
Next
If myOK = True Then
Open myFile For Output As #1
Print #1, myOutput
Close
myOK = False
End If
End Function
更多追问追答
追问
代码经测试可以用,但每次点击按钮后在abc文件夹中增加一个“新建文本文档”,这个没有必要,需要去掉。希望能改进一下。
追答
这个“新建文本文档”应该不是程序产生的。是不是原来文件夹中就存在这个文件?如有请删除后再运行看看。我运行后没发现你说的这个问题。
展开全部
Private Sub Command1_Click()
dim txt as integer
test=text1.text
If Dir("C:\abc\text.text", vbDirectory) <> "" Then
MsgBox "文件夹:C:\WINDOWS\system32\roect 存在!"
Else
MkDir "C:\abc\text.text"
If (Asc(test) >= 48 And Asc(TemporarySave) <= 57) Then
For n = 0 To UBound(test)
If IsNumeric(test(n)) = False Then testa(n) = ""
Next
s = Join(test, vbCrLf)
Set ts = fil1.OpenAsTextStream(ForWriting)
ts.Write s
ts.Close
End If
End Sub
dim txt as integer
test=text1.text
If Dir("C:\abc\text.text", vbDirectory) <> "" Then
MsgBox "文件夹:C:\WINDOWS\system32\roect 存在!"
Else
MkDir "C:\abc\text.text"
If (Asc(test) >= 48 And Asc(TemporarySave) <= 57) Then
For n = 0 To UBound(test)
If IsNumeric(test(n)) = False Then testa(n) = ""
Next
s = Join(test, vbCrLf)
Set ts = fil1.OpenAsTextStream(ForWriting)
ts.Write s
ts.Close
End If
End Sub
追问
我是要处理一个程序目录下一个文件夹中所有的txt文件,不是一个文件,而且文件名是不清楚的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
-- 1行 Perl 解决问题
perl -i -pe "s/^[^\n]*?[^\d\s[:punct:]\r\n][^\r\n]*\r?$[\n]//m" *.txt
别和我提什么Commandbar~~
perl -i -pe "s/^[^\n]*?[^\d\s[:punct:]\r\n][^\r\n]*\r?$[\n]//m" *.txt
别和我提什么Commandbar~~
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
fso对象的subfiles遍历某文件夹下的所有文件,过滤出txt文件,然后将3楼的代码做成一个函数,参数为文件名,即可完成
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以用ASC函数来判断它的码值来判断是否是数字(数字的码值是48----57)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
直接以FSO对象,打开文件,进行处理,很方便
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询