51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 2079|回复: 5
打印 上一主题 下一主题

[求助] 【已解决】Excel-Ado编程

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2013-6-17 16:58:08 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 liqiuheng 于 2013-6-20 13:26 编辑

如下代码,可以运行

sqlconnection="DSN=excel files;DBQ=D:\2.xls"
sqlcommand="Update [Sheet1$] set [Password]='1234' where [Username]='QuickTest'"
Set oExcel=CreateObject("adodb.connection")
oExcel.Open sqlconnection
oExcel.Execute(sqlcommand)
oExcel.Close
Set oExcel=nothing

但当把 [Password]='1234' 改成 [Password]='Testing'就出错了(不能赋值成string)

[Microsoft][ODBC Excel 驱动程序] 标准表达式中数据类型不匹配。
Line (5): "oExcel.Execute(sqlcommand)".

请问该怎么改才能运行?提前谢过了
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
发表于 2013-6-17 19:34:23 | 只看该作者
同求
回复 支持 反对

使用道具 举报

该用户从未签到

3#
 楼主| 发表于 2013-6-19 18:33:59 | 只看该作者
处理了一下excel里Password列的格式,在数字前加上单引号,把数字转化成文本,执行就没有问题了。
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2013-6-20 08:46:35 | 只看该作者
回复 3# liqiuheng


    额 就是讲excel转化成文本模式嘛
回复 支持 反对

使用道具 举报

该用户从未签到

5#
 楼主| 发表于 2013-6-20 13:22:45 | 只看该作者
数字不需要用引号 set [Password]='1234':
改为 set [Password]=1234 就可以了
回复 支持 反对

使用道具 举报

  • TA的每日心情
    奋斗
    2015-3-2 10:04
  • 签到天数: 1 天

    连续签到: 1 天

    [LV.1]测试小兵

    6#
    发表于 2013-6-25 10:06:15 | 只看该作者
    sqlconnection="Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" & FilePath & ";Extended Properties=""Excel 8.0;HDR=yes;IMEX=0"""     '其中IMEX=0表示更新操作
    sqlcommand="Update [Sheet1$] set [Password]=""1234"" where [Username]=""QuickTest"""
    Set oExcel=CreateObject("adodb.connection")
    oExcel.Open sqlconnection
    oExcel.Execute(sqlcommand)
    oExcel.Close
    Set oExcel=nothing
    回复 支持 反对

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-4-26 14:57 , Processed in 0.091433 second(s), 27 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

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