File: delete_layouts.rst

package info (click to toggle)
ezdxf 1.4.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 104,528 kB
  • sloc: python: 182,341; makefile: 116; lisp: 20; ansic: 4
file content (82 lines) | stat: -rw-r--r-- 1,559 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
.. _delete_layouts:

Delete Layouts and Blocks
=========================

Modelspace
----------

This is not possible.

Paperspace Layouts
------------------

Delete a paperspace layout and it's entities.

.. code-block::

    name = "MyLayout"
    try:
        doc.layouts.delete(name)
    except ezdxf.DXFKeyError:
        print(f"layout '{name}' not found")
    except ezdxf.DXFValueError:
        print(f"layout '{name}' cannot be deleted")
        # modelspace or last remaining paperspace layout

Block Definitions
-----------------

Delete a block definition:

.. code-block::

    try:
        doc.blocks.delete_block(name, safe=True)
    except ezdxf.DXFBlockInUseError:
        print(f"cannot delete block '{name}'")

Raises a :class:`DXFBlockInUseError` exception if the block is referenced by an INSERT
entity or if it is an anonymous/special block.

Purge/delete unused (unreferenced) block definitions:

.. versionadded:: 1.3.5

.. code-block::

    from ezdxf import blkrefs

    ...

    for name in blkrefs.find_unreferenced_blocks(doc)
        doc.blocks.delete_block(name, safe=False)

.. seealso::

    **Tasks:**

    - :ref:`add_layouts`
    - :ref:`get_layouts`
    - :ref:`add_blockrefs`
    - :ref:`delete_dxf_entities`

    **Tutorials:**

    - :ref:`tut_blocks`

    **Basics:**

    - :ref:`layout`
    - :ref:`modelspace_concept`
    - :ref:`paperspace_concept`
    - :ref:`block_concept`

    **Classes:**

    - :class:`ezdxf.layouts.Layouts`
    - :class:`ezdxf.document.Drawing`

    **Modules:**

    - :mod:`ezdxf.blkrefs`