明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: 革天明

求数据写入EXCEL

  [复制链接]
发表于 2012-9-23 11:20:40 | 显示全部楼层
搞完美点当然好.
如果只是自己用,我觉得用文本文件写入带逗号的的格式,另存为csv格式,直接就可以用EXCEL打开了.这样操作可能简单得多.

点评

很实用!学到一招。  发表于 2025-3-5 11:02
我用的是TAB分割符的XLS格式,打开和保存时都会提示“打开的格式与标准格式不一致”,保存时更麻烦,所以最好是真正的EXCEL或数据库  发表于 2012-9-24 10:25
回复

使用道具 举报

 楼主| 发表于 2012-9-24 11:37:16 | 显示全部楼层
每天一顶,有好例子的发一个,谢谢了
回复

使用道具 举报

发表于 2012-9-24 12:31:50 | 显示全部楼层
我网上找的.你主要看最后一句
通过在明经、晓东里边转了一圈又一圈之后终于能从Excellibian把单元格的数据读出来了。但是,还有个大问题解决不了:
1.
(vla-put-visible xlapp 1);1-可见,0-隐藏
一句把所有打开的Excel文件都给隐藏掉了!!!!!

2.同样的
(vlax-invoke-method xlapp 'quit)
一句把所有打开的Excel文件都给关掉了!!!!!

如何处理,能够让我可以把数据读出来且不影响其它打开的Excel文件?或者这么说:是否可以不打开指定的Excel文件就能将其中的数据读出来?


(defun excel-get-data (/ xlapp xlfile fn H8)
  (vl-load-com)
  ;读取单元格数据
  (defun Excel-Get-CellValue(xlapp cell / xlsrng xlsval)
    (setq xlsrng (vlax-get-property xlapp "range" cell))
    (setq xlsval (vlax-variant-value (vlax-get-property xlsrng "Value")))
  )
  (setq xfile (getfiled "打开法兰计算文件" "" "xls" 8))
  (if (setq fn (findfile xfile))
    (if (setq xlapp (vlax-get-or-create-object "Excel.Application"))
      (progn
(vlax-invoke-method
   (vlax-get-property xlapp 'WorkBooks)
   'Open
   fn
)
(vla-put-visible xlapp 0);1-可见,0-隐藏

;单元格数据读取
(setq H8 (Excel-Get-CellValue xlapp "H8"))

;退出并关闭Excel进程
(vlax-invoke-method xlapp 'quit)
(vlax-release-object xlapp)
      )
     )
    )
  H8
)


问题已解决
下面是测试的程序:

;;;取出Excel文件中第一个工作表中指定单元格的数据
(defun c:ttt ()
  (Excel-Get-data)
)

(defun Excel-Get-data ( / xfile cell ADOCONNECT ADORECORDSET ConnectionString lst Sheet-name source cell-tmp cell-value)
  ;指定单元格的数据
  (defun Excel-Get-CellValue (Sheet-name cell)
    (setq source (strcat "SELECT * FROM [" Sheet-name cell":" cell "]"))
    (vlax-invoke-method  ADORecordset "Open" source ADOConnect 1 3 nil)
    (setq cell-tmp (vlax-safearray->list (vlax-variant-value (vlax-invoke-method ADORecordset "GetRows" 1))))
    (vlax-variant-value (car (car cell-tmp)))  
  )

  (setq xfile (getfiled "打开法兰计算文件" "" "xls" 8))
  (setq ADOConnect (vlax-get-or-create-object "ADODB.Connection"))
  (setq ADORecordset (vlax-get-or-create-object "ADODB.Recordset"))
  (setq ConnectionString (strcat "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" xfile ";Extended Properties=;Excel 8.0;HDR=No" ))
  (if (not
(vl-catch-all-error-p
   (vl-catch-all-apply
     (function vlax-invoke-method)
     (list ADOConnect "Open" ConnectionString  "admin" "" nil)
   )
)
      )
    (progn
      (setq lst
      (vlax-safearray->list
        (vlax-variant-value
   (vlax-invoke-method (vlax-invoke-method ADOConnect "OpenSchema" 4 ) "GetRows" 1)
        )
     )
      )
      (setq Sheet-name (vlax-variant-value (car (caddr lst))));确定"第一个"工作表的名称
      (setq cell-value (Excel-Get-CellValue Sheet-name "H16"));H16单元格
      (vlax-invoke-method ADORecordset "Close")
      (vlax-invoke-method ADOConnect "Close")
    )
    (progn
      (princ "\n打开Excel数据文件出错")
      (vl-catch-all-apply 'vlax-invoke-method (list ADOConnect "Close"))
      (setq cell-value nil)
    )
  )
  (vlax-release-object ADORecordset)
  (vlax-release-object ADOConnect)
  cell-value
)


>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>

不用ADO原来也是可以实现的

;退出并关闭Excel进程
(vlax-invoke-method xlapp 'quit)
(vlax-release-object xlapp)
上边两句改成以下内容即可

;退出并关闭Excel文件
(vlax-invoke-method
   (vlax-get-property xlapp 'ActiveWorkbook)   
   'close
)















  查看文章   
简单的LISP读取EXCEL文档的内容的例子2011-11-17 17:04;;简单示例lisp读取excel里的数据(没有判断容错功能)by snddd2000 2011-11-17
(setq excelapp0 (vlax-get-object "Excel.Application"))
;;excel程序对象,没开excel下边的都是白搭
(setq activeworkbook0 (vlax-get-property excelapp0 'ActiveWorkbook))
;;excel工作簿对象
(setq activesheet0 (vlax-get-property activeworkbook0 'ActiveSheet))
;;excel工作表对象
(setq cells0 (vlax-get-property activesheet0 'cells))
;;excel单元格对象
(setq a1 (vlax-get-property cells0 'item 1 1))
;;A1单元格对象
(setq a1-value (vlax-variant-value
(vlax-get-property (vlax-variant-value a1) 'text)
;;或者'value
)
)
;;A1里的值



(vlax-put-property cells0 'item 1 1 "123");_向A1单元格写文本



回复

使用道具 举报

发表于 2012-9-24 12:39:51 | 显示全部楼层
如果可以用vba来做的话,很简单的几句代码即可
回复

使用道具 举报

发表于 2012-9-24 13:04:43 | 显示全部楼层
转别人的,觉得是真正写入EXCEL
;;; 前不久从台湾买了一本书,其中有一个将块的一些信息提取到excel的程序很不错,拿来与诸位分享。
(defun c:blk2xls (/ apl-exit initexcel endexcel datacell dorow dotable appxls xlsworkbooks newbook newsheet newitem xlscells objs
                    count ent claves numrow title blkss blksub blk_qty k0 i0 blkname xscale yscale zscale rotang blkdxf numcol
                    insert0
                 )                     ; 1.定义离开函数
  (defun apl-exit (msg)
    (endexcel)
    (prompt msg)
    (setq *error* oer)
  )                                    ; 2.initexcel用来初始m excel
  (defun initexcel ()
    (setq appxls (vlax-get-or-create-object "excel.application")
          xlsworkbooks (vlax-get-property appxls "workbooks")
          newbook (vlax-invoke-method xlsworkbooks "add")
          newsheet (vlax-get-property newbook "sheets")
          newitem (vlax-get-property newsheet "item" 1)
          xlscells (vlax-get-property newitem "cells")
    )
    (vla-put-visible appxls :vlax-true)
  )                                    ; 3.endexcel用来释放excel
  (defun endexcel ()
    (vlax-release-object xlscells)
    (vlax-release-object newitem)
    (vlax-release-object newsheet)
    (vlax-release-object newbook)
    (vlax-release-object xlsworkbooks)
    (vlax-release-object appxls)
  )                                    ; 4.datacell将value填入numrow,col的格子中
  (defun datacell (nurow col value)
    (vlax-put-property xlscells "item" numrow col (vl-princ-to-string value))
  )
  (setq oer *error*
        *error* apl-exit
  )
  (vl-load-com)
  (initexcel)
  (setq numrow 1
        numcol 0
  )                                    ; 5.列出表头
  (datacell numrow (setq numcol (1+ numcol))
            "Bock name"
  )
  (datacell numrow (setq numcol (1+ numcol))
            "X scale"
  )
  (datacell numrow (setq numcol (1+ numcol))
            "Y scale"
  )
  (datacell numrow (setq numcol (1+ numcol))
            "Z scale"
  )
  (datacell numrow (setq numcol (1+ numcol))
            "Angle"
  )
  (datacell numrow (setq numcol (1+ numcol))
            "Number"
  )                                    ; 6.依次处理各图块的参考
  (setq blkdxf (tblnext "BLOCK" t))
  (while blkdxf                        ; while1
    (setq blkname (cdr (assoc 2 blkdxf))
          blkss (ssget "x" (list (cons 0 "INSERT") (cons 2 blkname)))
    )
    (setq i0 0)
    (if blkss
      (setq blkss_qty (sslength blkss)) ; 写出块的数量
      (setq blkss_qty 0)               ; 图面上没有这个块则数量为0
    )
    (while (< i0 blkss_qty)            ; while2 ;当有这个图块时;;;7.依条件建立图块参考的选集
      (setq insert0 (ssname blkss i0)
            xscale (cdr (assoc 41 (entget insert0)))
            yscale (cdr (assoc 42 (entget insert0)))
            zscale (cdr (assoc 43 (entget insert0)))
            rotang (cdr (assoc 50 (entget insert0)))
            blksub (ssget "x" (list (cons 0 "INSERT") (cons 2 blkname) (cons 41 xscale) (cons 42 yscale) (cons 43 zscale)
                                    (cons 50 rotang)
                              )
                   )
            blkss_qty (- blkss_qty (sslength blksub))
            numrow (1+ numrow)
            numcol 0
            k0 0
      )
      (while (< k0 (sslength blksub))  ; while3
        (setq blkss (ssdel (ssname blksub k0) blkss))
        (setq k0 (1+ k0))
      )                                ; end whlie3
                                       ; 8.写入资料
      (datacell numrow (setq numcol (1+ numcol))
                blkname
      )
      (datacell numrow (setq numcol (1+ numcol))
                (rtos xscale)
      )
      (datacell numrow (setq numcol (1+ numcol))
                (rtos yscale)
      )
      (datacell numrow (setq numcol (1+ numcol))
                (rtos zscale)
      )
      (datacell numrow (setq numcol (1+ numcol))
                (rtos (* 180 (/ rotang pi)))
      )
      (datacell numrow (setq numcol (1+ numcol))
                (rtos (sslength blksub) 2 0)
      )
    )                                  ; end while2
    (setq blkdxf (tblnext "BLOCK"))
  )                                    ; end while1 (endexcel)
  (setq *error* oer)
  (princ)
)
回复

使用道具 举报

发表于 2012-9-24 13:12:49 | 显示全部楼层
Sub aa() Dim xls As Excel.Application Set xls = New Excel.Application xls.DisplayAlerts = False xls.Quit Dim s As String s = Dir("c:/test.xls") If s = "" Then With xls.Workbooks.Add    .Sheets(1).[a1:f1] = Array("日期", "时间", "月份", "X", "L", "GG")    .SaveAs FileName:="c:\test.xls", Password:="123456"    .Close savechanges:=True End With Else xls.Workbooks.Open "c:\" & s, , , , "123456" xls.ActiveWorkbook.Sheets(1).[a65536].End(xlUp).Offset(1, 0).Resize(1, 6) = Array("日期", "时间", "月份", "X", "L", "GG") For i = 1 To xls.Workbooks.Count xls.Workbooks(i).Close savechanges:=True Next End If xls.DisplayAlerts = True xls.Quit Set xls = Nothing End Sub
回复

使用道具 举报

发表于 2012-9-24 13:13:54 | 显示全部楼层
  1. Sub aa()
  2. Dim xls As Excel.Application
  3. Set xls = New Excel.Application
  4. xls.DisplayAlerts = False
  5. xls.Quit
  6. Dim s As String
  7. s = Dir("c:/test.xls")
  8. If s = "" Then
  9. With xls.Workbooks.Add
  10.    .Sheets(1).[a1:f1] = Array("日期", "时间", "月份", "X", "L", "GG")
  11.    .SaveAs FileName:="c:\test.xls", Password:="123456"
  12.    .Close savechanges:=True
  13. End With
  14. Else
  15. xls.Workbooks.Open "c:" & s, , , , "123456"
  16. xls.ActiveWorkbook.Sheets(1).[a65536].End(xlUp).Offset(1, 0).Resize(1, 6) = Array("日期", "时间", "月份", "X", "L", "GG")
  17. For i = 1 To xls.Workbooks.Count
  18. xls.Workbooks(i).Close savechanges:=True
  19. Next
  20. End If
  21. xls.DisplayAlerts = True
  22. xls.Quit
  23. Set xls = Nothing
  24. End Sub

点评

用户定义类型未定义,出错在第二句Dim xls As Excel.Application  发表于 2012-9-24 16:31
回复

使用道具 举报

发表于 2012-9-24 13:20:49 | 显示全部楼层
帮楼主顶一下,,,,
回复

使用道具 举报

 楼主| 发表于 2012-9-24 16:33:25 | 显示全部楼层

如何修改注册表?startapp和vl-registry-write好像都不太好使

sscylh 发表于 2012-9-24 13:13

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
回复

使用道具 举报

发表于 2012-9-24 17:48:15 | 显示全部楼层
打开vbe编辑器,工具--引用--microsoft excel object libiray
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-10-25 15:04 , Processed in 0.190089 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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