导入数据时写入文件名称
时 间:2019-04-08 11:09:04
作 者:张志 ID:8 城市:上海 QQ:2851379730
摘 要:从N个Excel中导入数据时,每导入1个,给明细记录写入文件的名称,以区分是哪一天的数据。
正 文:
问:
我们公司在共享文件夹中会放很多固定的日报,csv格式的,日报名称是用时间命名的,但是文件里面没有日期。
经常需要把N天数据汇总一起做分析,但是由于日报本身没有日期,所以汇总一起后不知道具体某一条记录是哪一天的。请问access有什么好的方法,可以在导入时加一列字段把文件名一起导入进去?
如下图所示:
图一 共享文件夹中N个文件
图二 每个Excel文件中的数据
答:
在导入每一个Excel文件后,用更新查询批量写入文件的名称,具体代码如下:
'要引用Microsoft Office 11.0 Object Library. Dim i As Long Dim x As Integer Dim file As String Dim strDate As String DoCmd.SetWarnings False If MsgBox("您确认导入数据吗?", vbYesNo, "提示") = vbNo Then Exit Sub End If With Application.FileDialog(msoFileDialogFilePicker) .AllowMultiSelect = True '可多选 .Title = "请选择要导入的Excel表(可多选)" .Filters.Clear '清除文件过滤器 .Filters.Add "Excel Files", "*.xls;*.xlsx" '设置文件过滤器 ' .Show 'FileDialog 对象的 Show 方法显示对话框,并且返回 -1(如果您按 OK)和 0(如果您按 Cancel)。 If .Show = 0 Then MsgBox "你已取消本次操作", vbCritical, "操作提示" Exit Sub End If For i = 1 To .SelectedItems.Count file = .SelectedItems(i) DoCmd.TransferSpreadsheet acImport, 8, "tbl销售明细", file, True, "" x = InStr(file, "导入\") strDate = Mid(file, x + 3) strDate = Left(strDate, Len(strDate) - 4) DoCmd.RunSQL "Update tbl销售明细 SET 日期 = '" & strDate & "' Where 日期 Is Null" Next End With
视频演示:
点击链接:https://m.qlchat.com/wechat/page/short-knowledge/video-show?id=2000004213656151&liveId=840000166145996,用微信扫描查看。
示例下载:
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- Access对子窗体数据进行批...(10.30)
- 最精简的组合框行来源数据快速输...(10.25)
- Access仿平台的多值选择器...(10.24)
- 【Access日期区间段查询】...(10.22)
- 【Access源码示例】VBA...(10.12)
- Access累乘示例,Acce...(10.09)
- 数值8.88,把整数8去掉,转...(10.08)
- 【Access自定义函数】一个...(09.30)
- 【Access选项卡示例】Ac...(09.09)
学习心得
最新文章
- Access快速开发平台--对上传...(11.22)
- Access快速开发平台企业版--...(11.18)
- 不会用多表联合查询,多表查询没结果...(11.16)
- 【案例分享】主键字段值含有不间断空...(11.16)
- Access快速开发平台--后台D...(11.14)
- 微软Access邀测新Monaco...(11.12)
- Access列表框左右互选、列表框...(11.11)
- 高效率在导入数据前删除记录(11.10)
- Access报价单转订单示例代码(11.08)
- Access系统自带的日期选择器不...(11.08)