设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

12
返回列表 发新帖
楼主: petrelai
打印 上一主题 下一主题

[Access本身] 各们高手请帮忙!如何在ACCESS中取得EXCEL中的工作表名称?

[复制链接]
11#
 楼主| 发表于 2004-4-19 21:28:00 | 只看该作者
这样呀,现在我只能在一打开数据库时,如果没有进行月结时,就出现对话框了。
还有士豆,您所说我不知道在哪做起。
12#
发表于 2004-4-19 21:34:00 | 只看该作者
通過計劃任務就不一定要vbswsh之類的了,只要是可執行的程序都可.
依你的說法還要在程序中加一段自動關閉的程序.就相當於自動轉換了.
13#
发表于 2004-4-19 21:52:00 | 只看该作者
用脚本最简单,一个记事本搞定,以后修改也用不着到处找源程序和重新编译。

关于脚本写法,我好像贴过一个例子的。再贴一次吧,把下面用记事本保存为一个VBS后缀的文件,自己看着修改吧


'==================
'过程:生成发货统计
'==================
Sub CreateOutSum()
'声明变量
Dim Conn        '连接对象
Dim strConn     '连接字符串
Dim Rs    '记录集对象
Dim strDate    '查询日期
Dim GoodsID, GoodsName, Title   '产品编码,产品名称,报表标题
Dim xApp, xBook, xSheet 'EXCEL对象
Dim ID  '行计数器

    '获取日期
    strDate = InputBox("请输入查询的起始日期", "发货统计")
    If Not IsDate(strDate) Then
        MsgBox "日期格式错误!"
        Exit Sub
    End If
    '获取产品代码
    GoodsID = InputBox("请输入要查询的产品编码", "发货统计")
    If GoodsID = "" Then Exit Sub
    '初始化数据连接
    strConn = "DBQ=data.mdb;DefaultDir=;DRIVER={Microsoft Access Driver (*.mdb)}WD=327950288;"
    Set Conn = CreateObject("adodb.connection")
    Conn.Open strConn
    '检查产品代码
    Set Rs = Conn.Execute("select * from 货品档案 where GoodsID='" & GoodsID & "'")
    If Rs.EOF Then
        MsgBox "该产品不存在!"
        Exit Sub
    End If
    GoodsName = Rs("GoodsName")
    Title = "发货统计(" & Trim(Replace(Replace(GoodsName, "/", "-"), "\", "-")) & ")"
    '创建EXCEL对象
    Set xApp = CreateObject("excel.application")
    Set xBook = xApp.Workbooks.Open("c:\demo3.xls")
    xBook.SaveAs "c:\" & Title & ".xls"
    Set xSheet = xBook.Worksheets("Sheet1")
    xSheet.Range("A1") = Title
    xSheet.Range("I5") = DateValue(strDate)
    '填写每日发货量
    For i = 0 To 9
        Set Rs = Conn.Execute("SELECT Sum(Num) AS SumNum " & _
                              "FROM 发生记录 " & _
                              "WHERE ModeID='F1' And GoodsID='" & GoodsID & "' And ([Date]=#" & DateAdd("d", i, strDate) & "#) ")
        If Not Rs.EOF Then xSheet.Range("J" & (i + 5)) = Rs("SumNum")
    Next
    '填写各公司发货量
    ID = 0
    Set Rs = Conn.Execute("SELECT Sum(Num) As SumNum,First(ClientName) As FirstClientName " & _
                        "FROM 发生记录 INNER JOIN 客户档案 ON 客户档案.ClientID=发生记录.ClientID " & _
                        "WHERE ModeID='F1' And GoodsID='" & GoodsID & "' And ([Date] BETWEEN #" & strDate & "# AND #" & DateValue(strDate) + 9 & "#)" & _
                        "GROUP BY 客户档案.ClientID")
    Do While Not Rs.EOF
        xSheet.Range("K" & (ID + 5)) = Rs("FirstClientName")
        xSheet.Range("L" & (ID + 5)) = Rs("SumNum")
        ID = ID + 1
        Rs.movenext
    Loop
    '保存调拨单
    Set xSheet = Nothing
    xBook.Close True
    Set xBook = Nothing
    '释放对象变量
    xApp.Quit: Set xApp = Nothing
    Rs.Close: Set Rs = Nothing
    Conn.Close: Set Conn = Nothing

    MsgBox "发货统计已经创建完毕!"
End Sub

14#
 楼主| 发表于 2004-4-19 22:08:00 | 只看该作者
太长了吧。但我也看到好像要你自己输入日期的对话框的?
15#
发表于 2004-4-19 22:26:00 | 只看该作者
你可以在程序里控制啊,例如取当前系统日期
16#
 楼主| 发表于 2004-4-19 23:00:00 | 只看该作者
谢谢!我会慢慢研究的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-15 10:04 , Processed in 0.076048 second(s), 27 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表