ExcelTip.Net留存知识帖 ---【注:附件之前被网盘供应商清空后,现已修复-现已修复-现已修复为本地下载!】
现在位置:首页 > E问E答 > Excel VBA > 如何根据文本特点将数据文本复原为数据表?

如何根据文本特点将数据文本复原为数据表?

作者:绿色风 分类: 时间:2022-08-17 浏览:99
楼主
kevinchengcw
Q: 如何根据文本特点将数据文本复原为数据表?
A: 经常在文件导出后生成的是文本文件,在二次处理时数据难以像在Excel中处理那样方便,所以会经常想将文本再次转换成Excel文档,本文引用提问中一例演示将有规律的文本转化回表格的一种方式,代码如下:
  1. Sub test()
  2. Dim FSO, txtFile
  3. Dim Str, Resource, pName, DateFrom, DateTo As String
  4. Set FSO = CreateObject("scripting.filesystemobject")  '创建FSO项目用于操作文本文件
  5. Set txtFile = FSO.opentextfile(ThisWorkbook.Path & "\Consumption Details.txt", 1)   '利用FSO项目打开当前目录下的源数据文本文件
  6. Str = ""   '以下初始化各个变量值
  7. Resource = ""
  8. pName = ""
  9. DateFrom = ""
  10. DateTo = ""
  11. Do Until txtFile.AtEndOfStream   '循环直至文本文件结尾
  12.     Str = Trim(txtFile.readline)  '从文本文件中读取一行内容并去除两端的空格,然后赋值给字符串变量
  13.     If Str <> "" And Left(Str, 1) <> "_" And Left(Str, 11) <> "PART NUMBER" And Str <> "0.00" Then  '如果变量不存在无意义行的特征(注:根据文本文档中文本行的特征总结出的特征),则执行下述操作
  14.         If Left(Str, 20) = "PRODUCTION RESOURCE:" Then   '判断是否是以"PRODUCTION RESOURCE:"开头的文本,如果是则
  15.             Resource = Trim(Split(Replace(Str, "PRODUCTION RESOURCE:", ""), "NAME:")(0))  '将其替换为空后,以"NAME:"为分隔分成两段,前段去掉两端空格赋值给变量Resource(即Production Resource)
  16.             pName = Trim(Split(Replace(Str, "PRODUCTION RESOURCE:", ""), "NAME:")(1))   '后段赋值给变量pName(即Name内容)
  17.         ElseIf Left(Str, 10) = "DATE FROM:" Then   '否则,如果是以"DATE FROM:"开头,则利用同样的方式取得前后两个日期值赋值给变量DateFrom和DateTo(即起止日期段)
  18.             DateFrom = Split(Replace(Replace(Str, "DATE FROM:", ""), " ", ""), "TO:")(0)
  19.             DateTo = Split(Replace(Replace(Str, "DATE FROM:", ""), " ", ""), "TO:")(1)
  20.         Else   '如果都不是以上两种情况,则说明取得的是数据段,依据文本特点进行分段处理(注意去除两端空格)后放入对应单元格中
  21.             With Worksheets("sheet2")
  22.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row + 1, 1) = Resource
  23.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 2) = pName
  24.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 3) = DateFrom
  25.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 4) = DateTo
  26.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 5) = Trim(Left(Str, 21))
  27.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 6) = Trim(Mid(Str, 22, 35))
  28.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 7) = Trim(Mid(Str, 57, 9))
  29.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 8) = Trim(Mid(Str, 66, 14))
  30.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 9) = Trim(Mid(Str, 80, 11))
  31.                 .Cells(.Cells(.Rows.Count, 1).End(3).Row, 10) = Trim(Right(Str, 14))
  32.             End With
  33.         End If
  34.     End If
  35. Loop
  36. txtFile.Close   '关闭文本文件
  37. Set txtFile = Nothing  '清空项目
  38. Set FSO = Nothing
  39. End Sub

附原文件示例。
在sheet2中运行test宏即可看到处理结果。
Consumption Deatils.rar
2楼
xyf2210
学习了

免责声明

有感于原ExcelTip.Net留存知识的价值及部分知识具有的时间限定性因素, 经与ExcelTip.Net站长Apolloh商议并征得其同意, 现将原属ExcelTip.Net的知识帖采集资料于本站点进行展示, 供有需要的人士查询使用,也慰缅曾经的论坛时代。 所示各个帖子的原作者如对版权有异议, 可与本人沟通提出,或于本站点留言,我们会尽快处理。 在此,感谢ExcelTip.Net站长Apolloh的支持,感谢本站点所有人**绿色风(QQ:79664738)**的支持与奉献,特此鸣谢!
------本人网名**KevinChengCW(QQ:1210618015)**原ExcelTip.Net总版主之一

评论列表
sitemap