from pyautocad import Autocad

# 自動連接上cad,只要cad是開着的,就創建了一個<pyautocad.api.Autocad> 對象。這個對象連接最近打開的cad文件。
# 如果此時還沒有打開cad,將會創建一個新的dwg文件,並自動開啓cad軟件
acad = Autocad(create_if_not_exists=True)
acad.prompt("Hello, Autocad from Python")# acad.prompt() 用來在cad控制台中打印文字
print (acad.doc.Name) # acad.doc.Name儲存着cad最近打開的圖形名

运行结果:

Hello, Autocad from Python
Drawing2.dwg

from pyautocad import Autocad

# 自動連接上cad,只要cad是開着的,就創建了一個<pyautocad.api.Autocad> 對象。這個對象連接最近打開的cad文件。
# 如果此時還沒有打開cad,將會創建一個新的dwg文件,並自動開啓cad軟件
acad = Autocad(create_if_not_exists=True)
acad.prompt("Hello, Autocad from Python")# acad.prompt() 用來在cad控制台中打印文字
print (acad.doc.Name) # acad.doc.Name儲存着cad最近打開的圖形名 #導入APoint類是非常必要的,畫圖都是靠點來畫,而且CAD中所有的點都必須用APoint類進行包裹。APoint(10,30),
# 其中10代表點的x座標,30代表點的y座標。
from pyautocad import APoint
import math
acad.model.AddLine(p1,p2) # 畫直線,p1是畫線的第一個點,p2是第二個點
text = acad.model.AddText("{0}".format(text), p, 15) # 添加文本,第一個參數就是添加的文本字符串,第二p是被APoint類包裹的點,也就是說在哪個座標下顯示文本,15是文本字體大小
text.move(p1, p2) # 文本從p1點移動到p2點
acad.model.AddCircle(p, 10) # 畫圓,第一個參數p就是APoint類包裹的點,也就是圓心位置,第二參數10是半徑大小
acad.model.AddArc(p, radius, math.radians(90), math.radians(270)) # 畫圓弧,第一個參數是在哪個點畫圓弧,第二個參數是半徑,第三個是開始弧(弧度制,不是角度制),第四個點是結束弧。
# 保存cad圖到指定位置,第一個參數一定是保存的絕對路徑!!,64是保存的一種格式,筆者從1到100都試了一遍,
# 有一些是可以生成圖的,都是CAD可以打開的文件類型格式。其實跟着筆者寫64就好!
acad.doc.SaveAs("{0}".format('cadtest.dwg'), 64)

上面这个例子不可以运行,因为没有初始化点的坐标。

from pyautocad import Autocad, APoint
acad = Autocad(create_if_not_exists=True)
acad.prompt("Hello, Autocad from Python\n")
print(acad.doc.Name)
p1 = APoint(0, 0)
p2 = APoint(50, 25)
for i in range(5):
text = acad.model.AddText('Hi %s!' % i, p1, 2.5)
acad.model.AddLine(p1, p2)
acad.model.AddCircle(p1, 10)
p1.y += 10 dp = APoint(10, 0)
# !!!!!!!遍歷cad圖形對象以及訪問/修改對象屬性
for text in acad.iter_objects('Text'):
print('text: %s at: %s' % (text.TextString, text.InsertionPoint))
text.InsertionPoint = APoint(text.InsertionPoint) + dp for obj in acad.iter_objects(['Circle', 'Line']):
print(obj.ObjectName)

运行结果:

C:\Users\Qin\AppData\Local\Programs\Python\Python36\python.exe D:/statistics_chenqichao/20180313同济大学嘉定校区/parse1/wuyong_2.py
Hello, Autocad from Python

Drawing3.dwg
text: Hi 0! at: (0.0, 0.0, 0.0)
text: Hi 1! at: (0.0, 10.0, 0.0)
text: Hi 2! at: (0.0, 20.0, 0.0)
text: Hi 3! at: (0.0, 30.0, 0.0)
text: Hi 4! at: (0.0, 40.0, 0.0)
AcDbLine
AcDbCircle
AcDbLine
AcDbCircle
AcDbLine
AcDbCircle
AcDbLine
AcDbCircle
AcDbLine
AcDbCircle

Process finished with exit code 0

from pyautocad import Autocad, APoint
acad = Autocad(create_if_not_exists=True)
for item in acad.iter_objects("PolyLine"):
print(item.Coordinates)

上面的代码提取多段线的各顶点坐标。

https://www.smwenku.com/a/5bc0b8b62b717711c923e688/


python操作cad的更多相关文章

  1. 转载 Python 操作 MySQL 的正确姿势 - 琉璃块

    Python 操作 MySQL 的正确姿势 收录待用,修改转载已取得腾讯云授权 作者 |邵建永 编辑 | 顾乡 使用Python进行MySQL的库主要有三个,Python-MySQL(更熟悉的名字可能 ...

  2. Python(九) Python 操作 MySQL 之 pysql 与 SQLAchemy

    本文针对 Python 操作 MySQL 主要使用的两种方式讲解: 原生模块 pymsql ORM框架 SQLAchemy 本章内容: pymsql 执行 sql 增\删\改\查 语句 pymsql ...

  3. Python 【第六章】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

    Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度 ...

  4. 练习:python 操作Mysql 实现登录验证 用户权限管理

    python 操作Mysql 实现登录验证 用户权限管理

  5. Python操作MySQL

    本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb ...

  6. Python操作Mysql之基本操作

    pymysql python操作mysql依赖pymysql这个模块 下载安装 pip3 install pymysql 操作mysql python操作mysql的时候,是通过”游标”来进行操作的. ...

  7. Python操作RabbitMQ

    RabbitMQ介绍 RabbitMQ是一个由erlang开发的AMQP(Advanced Message Queue )的开源实现的产品,RabbitMQ是一个消息代理,从“生产者”接收消息并传递消 ...

  8. python操作日期和时间的方法

    不管何时何地,只要我们编程时遇到了跟时间有关的问题,都要想到 datetime 和 time 标准库模块,今天我们就用它内部的方法,详解python操作日期和时间的方法.1.将字符串的时间转换为时间戳 ...

  9. Python—操作redis

    Python操作redis 连接方式:点击 1.String 操作 redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建, ...

随机推荐

  1. 【SQL】SQL Server中存储过程的调试方法

    1.以管理员用户登录DB服务器,把域用户追加到「Administrators」组. 2.在本机上以域用户登录,启动VS. 3.追加DB连接 4.右击要debug的存储过程,选择「ストアドプロシージャに ...

  2. java thin方式连接oracle数据库

    本文主要描述通过thin方式连接oracle数据库 1.创建web project ,将D:\oracle\product\10.2.0\db_1\jdbc\lib(oracle安装目录)下的ojdb ...

  3. CSRF Token

    本文参考自:https://blog.csdn.net/lion19930924/article/details/50955000 目的是防御CSRF攻击. Token就是令牌,最大的特点就是随机性, ...

  4. Zabbix-20160817-高危SQL注入漏洞

    漏洞概述: zabbix是一个开源的企业级性能监控解决方案.近日,zabbix的jsrpc的profileIdx2参数存在insert方式的SQL注入漏洞,攻击者无需授权登陆即可登陆zabbix管理系 ...

  5. ThinkPHP3.1在多数据库连接下存储过程调用bug修正

    最近使用ThinkPHP3.1进行一个项目的开发,由于该项目需要连接多台不同的数据库,所以使用如下配置方法: <?php return array( //'配置项'=>'配置值' //数据 ...

  6. 16 nginx实现负载均衡

    一:nginx实现负载均衡-----------------原理-------------------------- (1) 反向代理后端如果有多台服务器,自然可形成负载均衡,但proxy_pass如 ...

  7. linux 经常使用命令

    帮助信息 ./configure -help|grep mysql 安装php ./configure --prefix=/usr/local/fastphp --with-mysql=mysqlnd ...

  8. linux find 根据条件查找文件

    版权为个人所有,欢迎转载如转载请说明出处.(东北大亨) http://www.cnblogs.com/northeastTycoon/p/5513231.html 1. 实现说明 按照某一个时间点查找 ...

  9. 用nvm管理windows nodejs时用npm全局安装的插件无法调用的解决方案

    在环境变量中啊新建变量NODE_PATH赋值为prefix设置的地址即 prefix=D:\Users\xxx\AppData\Roaming\nodejs\npm-global 然后把%NODE_P ...

  10. Vue 填坑系列(持续更新...)

    1.遇到页面显示不更新,数据已更新情况 vue-cli中: this.$nextTick(function () { this.x=x; })     以js引入vue的网页中: this.$set( ...