找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1151|回复: 6

[表格] (XD::Table:toCSV)AUTOCAD 表格或者表格型LST生成CSV文件

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2016-12-5 09:49:18 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Table:toCSV
调用格式: (XD::Table:toCSV tb fn)
参数说明: tb ------- 表格实体名 或 MxN字符串表
fn ------- CSV文件名(带路径)
返回值: t or nil
函数简介: AUTOCAD 表格或者表格型LST生成CSV文件
函数来源: 原创
函数作者: Lispboy
适用版本: XDRX API 
最后更新时间: 2016-12-05
备注: -
演示图片: -

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
本帖最后由 Lispboy 于 2016-12-5 09:54 编辑
(defun XD::Table:toCSV (tb fn / cols i isLst isTable lst rows x y)
  (cond
    ((and
       (= (type tb) 'ENAME)
       (setq isTable (xdrx_object_isa tb "AcDbTable"))
     )
     (setq rows        (xdrx_table_numrows tb)
           cols        (xdrx_table_numcolumns tb)
           i        -1
     )
     (repeat rows
       (setq i (1+ i))
       (setq lst (cons (xdrx_table_textstring tb i -1) lst))
     )
     (setq lst (reverse lst))
    )
    ((and
       (= (type tb) 'LIST)
       (setq isLst (xd::list:isTable tb))
     )
     (setq lst        tb
           rows        (car isLst)
           cols        (cadr isLst)
     )
    )
    (t
     (exit)
    )
  )
  (setq        lst (mapcar
              '(lambda (x)
                 (mapcar
                   '(lambda (y)
                      (cond
                        ((or
                           (not y)
                           (= y "")
                         )
                         ""
                        )
                        ((/= (type y) 'STR)
                         (vl-princ-to-string y)
                        )
                        (t
                         y
                        )
                      )
                    )
                   x
                 )
               )
              lst
            )
  )
  (setq        lst (mapcar
              '(lambda (x)
                 (xdrx_string_join x ",")
               )
              lst
            )
  )
  (xd::list:tofile fn lst)
  t
)


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 51个

财富等级: 招财进宝

 楼主| 发表于 2016-12-5 09:52:55 | 显示全部楼层
测试代码,选ACAD_TABLE实体,生成CSV
(defun c:tt()
  (if (and (setq e (car (xdrx_entsel "\n点取表格实体<退出>:" '((0 . "ACAD_TABLE")))))
           (setq fn (xdrx_system_selectfiles "CSV" "" "CSV" 1))
      )
    (XD::TABLE:TOCSV e (car fn))
  )
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1304个

财富等级: 财源广进

发表于 2016-12-5 10:27:52 | 显示全部楼层
啥也不说了,感谢楼主分享哇!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 127个

财富等级: 日进斗金

发表于 2016-12-5 15:30:41 | 显示全部楼层
支持!!!!!!!谢谢!!!!!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复

使用道具 举报

已领礼包: 2226个

财富等级: 金玉满堂

发表于 2016-12-5 22:57:56 | 显示全部楼层
啥也不说了,感谢楼主分享哇!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 6056个

财富等级: 富甲天下

发表于 2016-12-10 17:35:29 | 显示全部楼层
谢谢分享。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复

使用道具 举报

已领礼包: 1211个

财富等级: 财源广进

发表于 2016-12-14 08:32:44 | 显示全部楼层
正需要,支持楼主大人了!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-4-20 08:12 , Processed in 0.322912 second(s), 46 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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