Usage ===== Main interface and types ------------------------- .. currentmodule:: pyautocad.api For our first example, we will use :class:`Autocad` (main Automation object) and :class:`pyautocad.types.APoint` for operations with coordinates .. literalinclude:: example.py :lines: 3 Let's create AutoCAD application or connect to already running application: .. literalinclude:: example.py :lines: 5-7 To work with AutoCAD documents and objects we can use ActiveX interface, :class:`Autocad` (from pyautocad) contains some methods to simplify common Automation tasks, such as object iteration and searching, getting objects from user's selection, printing messages. There are shortcuts for current ``ActiveDocument`` - :attr:`Autocad.doc` and ``ActiveDocument.ModelSpace`` - :attr:`Autocad.model` Let's add some objects to document: .. literalinclude:: example.py :lines: 9-15 Now our document contains some ``Texts``, ``Lines`` and ``Circles``, let's iterate them all: .. literalinclude:: example.py :lines: 17-18 Wea can also iterate objects of concrete type: .. literalinclude:: example.py :lines: 20-21 .. note:: Object name can be partial and case insensitive, e.g. ``acad.iter_objects('tex')`` will return ``AcDbText`` and ``AcDbMText`` objects Or multiple types: .. literalinclude:: example.py :lines: 23-24 Also we can find first object with some conditions. For example, let's find first text item which contains ``3``: .. literalinclude:: example.py :lines: 26-30 To modify objects in document, we need to find interesting objects and change its properties. Some properties are described with constants, e.g. text alignment. These constants can be accessed through :data:`ACAD`. Let's change all text objects text alignment: .. literalinclude:: example.py :lines: 32-37 .. currentmodule:: pyautocad.types In previous code we have converted ``text.InsertionPoint`` to :class:`APoint` because we can't just use default ``tuple`` when setting another properties such as ``text.TextAlignmentPoint``. If wee need to change position of some object, we should use :class:`APoint`, for example let's change lines end position: .. literalinclude:: example.py :lines: 39-41 Working with tables ------------------- .. note:: To work with tables, xlrd_ and tablib_ should be installed. .. _xlrd: http://pypi.python.org/pypi/xlrd .. _tablib: http://pypi.python.org/pypi/tablib .. currentmodule:: pyautocad.contrib.tables To simplify importing and exporting data there is :class:`Table` class exist. It allows you to read and write tabular data in popular formats: - csv - xls - xlsx (write only) - json Let's try to solve some basic task. We need to save text and position from all text objects to Excel file, and then load it back. First we need to add some objects to AutoCAD: .. literalinclude:: example_tables.py :lines: 3-10 Now we can iterate this objects and save them to Excel table: .. literalinclude:: example_tables.py :lines: 12-16 After saving this data to 'data.xls' and probably changing it with some table processor software (e.g. Microsoft Office Excel) we can retrieve our data from file: .. literalinclude:: example_tables.py :lines: 18 ``data`` will contain:: [[u'Hi 0!', 0.0, 0.0, 0.0], [u'Hi 1!', 0.0, 10.0, 0.0], [u'Hi 2!', 0.0, 20.0, 0.0], [u'Hi 3!', 0.0, 30.0, 0.0], [u'Hi 4!', 0.0, 40.0, 0.0]] .. seealso:: Example of working with AutoCAD table objects at `examples/dev_get_table_info.py `_ Improve speed ------------- - ActiveX technology is quite slow. When you are accessing object attributes like position, text, etc, every time call is passed to AutoCAD. It can slowdown execution time. For example if you have program, which combines single line text based on its relative positions, you probably need to get each text position several times. To speed this up, you can cache objects attributes using the :class:`pyautocad.cache.Cached` proxy (see example in class documentation) - To improve speed of AutoCAD table manipulations, you can use ``Table.RegenerateTableSuppressed = True`` or handy context manager :func:`suppressed_regeneration_of(table) `:: table = acad.model.AddTable(pos, rows, columns, row_height, col_width) with suppressed_regeneration_of(table): table.SetAlignment(ACAD.acDataRow, ACAD.acMiddleCenter) for row in range(rows): for col in range(columns): table.SetText(row, col, '%s %s' % (row, col)) Utility functions ----------------- There is also some utility functions for work with AutoCAD text objects and more. See :mod:`pyautocad.utils` documentation.