乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 90|回复: 9

[编程交流] 转换单个字符i

[复制链接]

22

主题

272

帖子

254

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2022-7-6 07:19:45 | 显示全部楼层 |阅读模式
将pdf转换为dxf后,所有转换的文本显示为单个字符(如图所示)。有没有办法使用lisp将其转换回单词和句子?
081956q04c0ccp040km502.jpg
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-7-6 07:32:40 | 显示全部楼层
可以这样做,只需制作一个字符及其x插入位置的“列表”x的原因是它们可能没有按照查看的顺序创建,因此您的列表必须反映查看时的连续字符串,然后您可以使用字符之间的距离因子来暗示一个空格,因为空格不存在。倾斜文本??
 
快速思考文本非perp使用左下边界框点,而不是插入pt来计算顺序。
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-6 07:38:20 | 显示全部楼层
试试这个马瑞克。
 
  1. (defun c:GatherTexts (/ ss i sn e lst l st)
  2. ;;;;;            Tharwat 01. Nov. 2012            ;;;;;
  3. ;;;;;        gathering TEXT entities all together in        ;;;;;
  4. ;;;;;        the first left entity from the selection set    ;;;;;
  5. (or acdoc (setq acdoc (vla-get-activedocument (vlax-get-acad-object))))
  6. (if (setq ss (ssget "_:L" '((0 . "TEXT"))))
  7.    (progn (repeat (setq i (sslength ss))
  8.             (setq sn (ssname ss (setq i (1- i))))
  9.             (setq e (entget sn))
  10.             (setq lst (cons (list (cdr (assoc 10 e)) (cdr (assoc 1 e)) sn) lst))
  11.           )
  12.           (setq l (vl-sort lst '(lambda (a b) (< (car (car a)) (car (car b))))))
  13.           (setq st (apply 'strcat (mapcar 'cadr l)))
  14.           (vla-StartUndoMark acdoc)
  15.           (if (entmod (subst (cons 1 st) (assoc 1 (entget (caddr (car l)))) (entget (caddr (car l)))))
  16.             (progn (setq l (reverse l)) (setq l (vl-remove (last l) l)) (mapcar 'entdel (mapcar 'caddr l)))
  17.           )
  18.           (vla-EndUndomark acdoc)
  19.    )
  20.    (princ)
  21. )
  22. (princ)
  23. )
回复

使用道具 举报

22

主题

272

帖子

254

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2022-7-6 07:44:50 | 显示全部楼层
如果你是Tharwat,它工作得很好,但只适用于水平和倾斜文本。如果文字是垂直的:则将其反转。我不知道这是选择方式的问题(我想我尝试了所有方法)还是需要为代码做些什么。
如果您愿意,可以使用一个示例dwg进行测试。
测验图纸
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-6 07:50:07 | 显示全部楼层
很抱歉造成混淆,这是因为我只编写了水平文本的代码,所以现在试试。
 
  1. (defun c:Test (/ ss i sn e lst l st p r)
  2. ;;;;;            Tharwat 01. Nov. 2012            ;;;;;
  3. ;;;;;        gathering TEXT entities all together in        ;;;;;
  4. ;;;;;        the first left entity from the selection set    ;;;;;
  5. (or acdoc (setq acdoc (vla-get-activedocument (vlax-get-acad-object))))
  6. (if (setq ss (ssget "_:L" '((0 . "TEXT"))))
  7.    (progn (repeat (setq i (sslength ss))
  8.             (setq sn (ssname ss (setq i (1- i))))
  9.             (setq e (entget sn))
  10.             (setq lst (cons (list (cdr (assoc 10 e)) (cdr (assoc 1 e)) sn) lst))
  11.           )
  12.           (setq l (vl-sort lst '(lambda (a b) (< (car (car a)) (car (car b))))))
  13.           (setq st (apply 'strcat (mapcar 'cadr l)))
  14.           (setq p (mapcar 'car (mapcar 'car lst)))
  15.           (foreach x p
  16.             (if (equal x (car p))
  17.               (setq r (cons x r))
  18.             )
  19.           )
  20.           (vla-StartUndoMark acdoc)
  21.           (if (eq (length r) (length p))
  22.             (progn (setq st (vl-list->string (reverse (vl-string->list st))))
  23.                    (if (entmod (subst (cons 1 st) (assoc 1 (entget (caddr (last l)))) (entget (caddr (last l)))))
  24.                      (progn (setq l (reverse l)) (setq l (vl-remove (car l) l)) (mapcar 'entdel (mapcar 'caddr l)))
  25.                    )
  26.             )
  27.             (if (entmod (subst (cons 1 st) (assoc 1 (entget (caddr (car l)))) (entget (caddr (car l)))))
  28.               (progn (setq l (reverse l)) (setq l (vl-remove (last l) l)) (mapcar 'entdel (mapcar 'caddr l)))
  29.             )
  30.           )
  31.           (vla-EndUndomark acdoc)
  32.    )
  33.    (princ)
  34. )
  35. (princ)
  36. )
回复

使用道具 举报

22

主题

272

帖子

254

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2022-7-6 07:53:10 | 显示全部楼层
塔瓦,你是个完美的人。
我想为没有提及各种文本旋转而道歉。
干得好,非常感谢。我真的很感激。
回复

使用道具 举报

63

主题

6297

帖子

6283

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
358
发表于 2022-7-6 07:59:53 | 显示全部楼层
 
听到这个消息我很高兴。
 
非常欢迎你,马瑞克。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 08:11:58 | 显示全部楼层
这是我的版本:
上述应正确处理在任何旋转时对齐的字符。
 
使用文件中的示例:
 
回复

使用道具 举报

22

主题

272

帖子

254

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
111
发表于 2022-7-6 08:16:38 | 显示全部楼层
另一个很棒的。谢谢你,李。现在我可以一次选中所有项目,一次完成。完美的非常感谢你。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 08:20:22 | 显示全部楼层
 
谢谢你,马瑞克,不客气。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-8-15 12:08 , Processed in 1.159668 second(s), 76 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表