dimine-python-sdk 0.1.8__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- dimine_python_sdk/__init__.py +13 -0
- dimine_python_sdk/conn/__init__.py +5 -0
- dimine_python_sdk/conn/base_conn_client.py +167 -0
- dimine_python_sdk/conn/conn_client.py +382 -0
- dimine_python_sdk/docs/guides/data_edit.md +306 -0
- dimine_python_sdk/docs/guides/data_get.md +266 -0
- dimine_python_sdk/docs/guides/data_types.md +152 -0
- dimine_python_sdk/docs/guides/features.md +271 -0
- dimine_python_sdk/docs/guides/io.md +157 -0
- dimine_python_sdk/docs/index.md +41 -0
- dimine_python_sdk/docs/quickstart.md +45 -0
- dimine_python_sdk/docs/reference/SUMMARY.md +19 -0
- dimine_python_sdk/docs/reference/conn/base_conn_client.md +3 -0
- dimine_python_sdk/docs/reference/conn/conn_client.md +3 -0
- dimine_python_sdk/docs/reference/lib/algorithm/model_func.md +3 -0
- dimine_python_sdk/docs/reference/lib/io/file_conversion.md +3 -0
- dimine_python_sdk/docs/reference/lib/io/models.md +3 -0
- dimine_python_sdk/docs/reference/lib/io/project_plotting.md +3 -0
- dimine_python_sdk/docs/reference/lib/prospecting/block_data.md +3 -0
- dimine_python_sdk/docs/reference/lib/prospecting/drill_db.md +3 -0
- dimine_python_sdk/docs/reference/lib/prospecting/models.md +3 -0
- dimine_python_sdk/docs/reference/lib/prospecting/valuation.md +3 -0
- dimine_python_sdk/docs/reference/lib/types/entity.md +3 -0
- dimine_python_sdk/docs/reference/lib/types/line.md +3 -0
- dimine_python_sdk/docs/reference/lib/types/point.md +3 -0
- dimine_python_sdk/docs/reference/logger.md +3 -0
- dimine_python_sdk/docs/reference/models/conn.md +3 -0
- dimine_python_sdk/docs/reference/models/errors.md +3 -0
- dimine_python_sdk/docs/reference/models/types.md +3 -0
- dimine_python_sdk/docs/summary.md +6 -0
- dimine_python_sdk/lib/__init__.py +20 -0
- dimine_python_sdk/lib/algorithm/__init__.py +1 -0
- dimine_python_sdk/lib/algorithm/model_func.py +219 -0
- dimine_python_sdk/lib/exploitation/__init__.py +0 -0
- dimine_python_sdk/lib/io/__init__.py +2 -0
- dimine_python_sdk/lib/io/file_conversion.py +143 -0
- dimine_python_sdk/lib/io/models.py +180 -0
- dimine_python_sdk/lib/io/project_plotting.py +40 -0
- dimine_python_sdk/lib/prospecting/__init__.py +3 -0
- dimine_python_sdk/lib/prospecting/block_data.py +289 -0
- dimine_python_sdk/lib/prospecting/drill_db.py +333 -0
- dimine_python_sdk/lib/prospecting/models.py +276 -0
- dimine_python_sdk/lib/prospecting/valuation.py +113 -0
- dimine_python_sdk/lib/types/__init__.py +4 -0
- dimine_python_sdk/lib/types/entity.py +957 -0
- dimine_python_sdk/lib/types/line.py +188 -0
- dimine_python_sdk/lib/types/point.py +695 -0
- dimine_python_sdk/logger.py +7 -0
- dimine_python_sdk/models/__init__.py +3 -0
- dimine_python_sdk/models/conn.py +53 -0
- dimine_python_sdk/models/errors.py +4 -0
- dimine_python_sdk/models/types.py +131 -0
- dimine_python_sdk/site/404.html +671 -0
- dimine_python_sdk/site/assets/_mkdocstrings.css +237 -0
- dimine_python_sdk/site/assets/images/favicon.png +0 -0
- dimine_python_sdk/site/assets/javascripts/bundle.79ae519e.min.js +16 -0
- dimine_python_sdk/site/assets/javascripts/bundle.79ae519e.min.js.map +7 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.ar.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.da.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.de.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.du.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.el.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.es.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.fi.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.fr.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.he.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.hi.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.hu.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.hy.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.it.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.ja.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.jp.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.kn.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.ko.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.multi.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.nl.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.no.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.pt.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.ro.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.ru.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.sa.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.stemmer.support.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.sv.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.ta.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.te.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.th.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.tr.min.js +18 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.vi.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/min/lunr.zh.min.js +1 -0
- dimine_python_sdk/site/assets/javascripts/lunr/tinyseg.js +206 -0
- dimine_python_sdk/site/assets/javascripts/lunr/wordcut.js +6708 -0
- dimine_python_sdk/site/assets/javascripts/workers/search.2c215733.min.js +42 -0
- dimine_python_sdk/site/assets/javascripts/workers/search.2c215733.min.js.map +7 -0
- dimine_python_sdk/site/assets/stylesheets/main.484c7ddc.min.css +1 -0
- dimine_python_sdk/site/assets/stylesheets/main.484c7ddc.min.css.map +1 -0
- dimine_python_sdk/site/assets/stylesheets/palette.ab4e12ef.min.css +1 -0
- dimine_python_sdk/site/assets/stylesheets/palette.ab4e12ef.min.css.map +1 -0
- dimine_python_sdk/site/guides/data_edit.html +1251 -0
- dimine_python_sdk/site/guides/data_get.html +1206 -0
- dimine_python_sdk/site/guides/data_types.html +1529 -0
- dimine_python_sdk/site/guides/features.html +1217 -0
- dimine_python_sdk/site/guides/io.html +1025 -0
- dimine_python_sdk/site/index.html +849 -0
- dimine_python_sdk/site/objects.inv +0 -0
- dimine_python_sdk/site/quickstart.html +859 -0
- dimine_python_sdk/site/reference/SUMMARY.html +729 -0
- dimine_python_sdk/site/reference/conn/base_conn_client.html +1295 -0
- dimine_python_sdk/site/reference/conn/conn_client.html +3551 -0
- dimine_python_sdk/site/reference/lib/algorithm/model_func.html +2162 -0
- dimine_python_sdk/site/reference/lib/io/file_conversion.html +1725 -0
- dimine_python_sdk/site/reference/lib/io/models.html +1625 -0
- dimine_python_sdk/site/reference/lib/io/project_plotting.html +984 -0
- dimine_python_sdk/site/reference/lib/prospecting/block_data.html +2455 -0
- dimine_python_sdk/site/reference/lib/prospecting/drill_db.html +2836 -0
- dimine_python_sdk/site/reference/lib/prospecting/models.html +2309 -0
- dimine_python_sdk/site/reference/lib/prospecting/valuation.html +1373 -0
- dimine_python_sdk/site/reference/lib/types/entity.html +6728 -0
- dimine_python_sdk/site/reference/lib/types/line.html +1985 -0
- dimine_python_sdk/site/reference/lib/types/point.html +3672 -0
- dimine_python_sdk/site/reference/logger.html +751 -0
- dimine_python_sdk/site/reference/models/conn.html +751 -0
- dimine_python_sdk/site/reference/models/errors.html +802 -0
- dimine_python_sdk/site/reference/models/types.html +1679 -0
- dimine_python_sdk/site/search/search_index.json +1 -0
- dimine_python_sdk/site/sitemap.xml +107 -0
- dimine_python_sdk/site/sitemap.xml.gz +0 -0
- dimine_python_sdk/site/summary.html +697 -0
- dimine_python_sdk-0.1.8.dist-info/METADATA +15 -0
- dimine_python_sdk-0.1.8.dist-info/RECORD +135 -0
- dimine_python_sdk-0.1.8.dist-info/WHEEL +5 -0
- dimine_python_sdk-0.1.8.dist-info/top_level.txt +2 -0
- tests/conn_test.py +250 -0
- tests/test_base_type.py +143 -0
- tests/ws_client.py +60 -0
- tests/ws_server.py +271 -0
|
@@ -0,0 +1,957 @@
|
|
|
1
|
+
import DmPyBindInterface as Dm
|
|
2
|
+
from dimine_python_sdk.lib.types.line import DmDbPolyline, DmDbLine
|
|
3
|
+
from dimine_python_sdk.lib.types.point import DmDPoint, DmPoints, DmDbPoint
|
|
4
|
+
from enum import IntEnum
|
|
5
|
+
from typing import Optional, List, Union
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
class EntityType(IntEnum):
|
|
9
|
+
ETT_NUKNOWN = -1
|
|
10
|
+
ETT_POINT = 0
|
|
11
|
+
ETT_LINE = 1
|
|
12
|
+
ETT_POLYLINE = 2
|
|
13
|
+
ETT_SHELL = 3
|
|
14
|
+
ETT_TEXT = 4
|
|
15
|
+
ETT_ARC = 5
|
|
16
|
+
ETT_CIRCLE = 6
|
|
17
|
+
ETT_ELLIPSE = 7
|
|
18
|
+
ETT_SPLINE = 8
|
|
19
|
+
ETT_POLYGON = 9
|
|
20
|
+
ETT_ANNOTATION = 10
|
|
21
|
+
ETT_SPHERE = 11
|
|
22
|
+
ETT_UGRID = 12
|
|
23
|
+
ETT_WORKPLANE = 13
|
|
24
|
+
ETT_NET_NODE = 15
|
|
25
|
+
ETT_NET_EDGE = 16
|
|
26
|
+
ETT_MODEL = 17
|
|
27
|
+
ETT_COMPLEX = 18
|
|
28
|
+
ETT_2DPOLYLINE = 19
|
|
29
|
+
ETT_LWPOLYLINE = 20
|
|
30
|
+
ETT_BLOCK = 21
|
|
31
|
+
ETT_MBLOCK = 22
|
|
32
|
+
ETT_HATCH = 23
|
|
33
|
+
ETT_Ordinate_Dim = 24
|
|
34
|
+
ETT_Aligned_Dim = 25
|
|
35
|
+
ETT_Rotated_Dim = 26
|
|
36
|
+
ETT_3PointAngular_Dim = 27
|
|
37
|
+
ETT_2LineAngular_Dim = 28
|
|
38
|
+
ETT_Radial_Dim = 29
|
|
39
|
+
ETT_Diametric_Dim = 30
|
|
40
|
+
ETT_Arc_Dim = 31
|
|
41
|
+
ETT_Radial_Large_Dim = 32
|
|
42
|
+
ETT_MTEXT = 33
|
|
43
|
+
ETT_MESH = 34
|
|
44
|
+
ETT_IMAGE = 35
|
|
45
|
+
ETT_XLINE = 36
|
|
46
|
+
ETT_RAY = 37
|
|
47
|
+
ETT_LEADER = 38
|
|
48
|
+
ETT_MLINE = 39
|
|
49
|
+
ETT_TABLE = 40
|
|
50
|
+
ETT_ATT_DEF = 41
|
|
51
|
+
ETT_ATT = 42
|
|
52
|
+
ETT_POINT_SET = 43
|
|
53
|
+
ETT_TEXT_SET = 44
|
|
54
|
+
ETT_POLYHEDRALSURFACETYPE = 45
|
|
55
|
+
ETT_CUSTOM_START = 100
|
|
56
|
+
|
|
57
|
+
|
|
58
|
+
#三维实体
|
|
59
|
+
class DmDbShell:
|
|
60
|
+
"""shell类"""
|
|
61
|
+
def __init__(self):
|
|
62
|
+
"""构造函数,初始化Shell对象"""
|
|
63
|
+
self._obj = Dm.dmDbShell()
|
|
64
|
+
|
|
65
|
+
@classmethod
|
|
66
|
+
def _from_obj(cls, obj):
|
|
67
|
+
"""
|
|
68
|
+
原生对象创建封装实例
|
|
69
|
+
:param obj: 原生dmDbShell对象
|
|
70
|
+
:return: DmDbShell实例
|
|
71
|
+
"""
|
|
72
|
+
instance = cls.__new__(cls)
|
|
73
|
+
instance._obj = obj
|
|
74
|
+
return instance
|
|
75
|
+
|
|
76
|
+
#几何数据
|
|
77
|
+
class DmPolyData:
|
|
78
|
+
"""多边形数据类"""
|
|
79
|
+
|
|
80
|
+
def __init__(self):
|
|
81
|
+
"""
|
|
82
|
+
构造函数:初始化多边形数据对象
|
|
83
|
+
:return: None
|
|
84
|
+
"""
|
|
85
|
+
self._obj = Dm.dmPolyData()
|
|
86
|
+
|
|
87
|
+
# ---------------------- 基础属性获取 ----------------------
|
|
88
|
+
def get_data_type(self) -> int:
|
|
89
|
+
"""
|
|
90
|
+
获取多边形数据类型
|
|
91
|
+
:return: 数据类型编码(整数)
|
|
92
|
+
|
|
93
|
+
example:
|
|
94
|
+
```python
|
|
95
|
+
poly_data = DmPolyData()
|
|
96
|
+
data_type = poly_data.get_data_type()
|
|
97
|
+
```
|
|
98
|
+
"""
|
|
99
|
+
return self._obj.GetDataType()
|
|
100
|
+
|
|
101
|
+
def get_number_of_cells(self) -> int:
|
|
102
|
+
"""
|
|
103
|
+
获取单元格数量
|
|
104
|
+
:return: 单元格数量(整数)
|
|
105
|
+
|
|
106
|
+
example:
|
|
107
|
+
```python
|
|
108
|
+
poly_data = DmPolyData()
|
|
109
|
+
num_cells = poly_data.get_number_of_cells()
|
|
110
|
+
```
|
|
111
|
+
"""
|
|
112
|
+
return self._obj.GetNumberOfCells()
|
|
113
|
+
|
|
114
|
+
def get_number_of_verts(self) -> int:
|
|
115
|
+
"""
|
|
116
|
+
获取顶点数量
|
|
117
|
+
:return: 顶点数量(整数)
|
|
118
|
+
|
|
119
|
+
example:
|
|
120
|
+
```python
|
|
121
|
+
poly_data = DmPolyData()
|
|
122
|
+
num_verts = poly_data.get_number_of_verts()
|
|
123
|
+
```
|
|
124
|
+
"""
|
|
125
|
+
return self._obj.GetNumberOfVerts()
|
|
126
|
+
|
|
127
|
+
def get_number_of_lines(self) -> int:
|
|
128
|
+
"""
|
|
129
|
+
获取线段数量
|
|
130
|
+
:return: 线段数量(整数)
|
|
131
|
+
|
|
132
|
+
example:
|
|
133
|
+
```python
|
|
134
|
+
poly_data = DmPolyData()
|
|
135
|
+
num_lines = poly_data.get_number_of_lines()
|
|
136
|
+
```
|
|
137
|
+
"""
|
|
138
|
+
return self._obj.GetNumberOfLines()
|
|
139
|
+
|
|
140
|
+
def get_number_of_polys(self) -> int:
|
|
141
|
+
"""
|
|
142
|
+
获取多边形数量
|
|
143
|
+
:return: 多边形数量(整数)
|
|
144
|
+
|
|
145
|
+
example:
|
|
146
|
+
```python
|
|
147
|
+
poly_data = DmPolyData()
|
|
148
|
+
num_polys = poly_data.get_number_of_polys()
|
|
149
|
+
```
|
|
150
|
+
"""
|
|
151
|
+
return self._obj.GetNumberOfPolys()
|
|
152
|
+
|
|
153
|
+
def get_number_of_points(self) -> int:
|
|
154
|
+
"""
|
|
155
|
+
获取点的总数量
|
|
156
|
+
:return: 点数量(整数)
|
|
157
|
+
|
|
158
|
+
example:
|
|
159
|
+
```python
|
|
160
|
+
poly_data = DmPolyData()
|
|
161
|
+
num_points = poly_data.get_number_of_points()
|
|
162
|
+
```
|
|
163
|
+
"""
|
|
164
|
+
return self._obj.GetNumberOfPoints()
|
|
165
|
+
|
|
166
|
+
def get_bounds(self) -> list[float]:
|
|
167
|
+
"""
|
|
168
|
+
获取数据的包围盒
|
|
169
|
+
:return: 包围盒坐标列表 [min_x, max_x, min_y, max_y, min_z, max_z]
|
|
170
|
+
|
|
171
|
+
example:
|
|
172
|
+
```python
|
|
173
|
+
poly_data = DmPolyData()
|
|
174
|
+
bounds = poly_data.get_bounds()
|
|
175
|
+
```
|
|
176
|
+
"""
|
|
177
|
+
return self._obj.GetBounds()
|
|
178
|
+
|
|
179
|
+
# ---------------------- 单元格插入 ----------------------
|
|
180
|
+
def insert_next_vert_cell(self, point_indexes: list[int]) -> None:
|
|
181
|
+
"""
|
|
182
|
+
插入顶点单元格
|
|
183
|
+
:param point_indexes: 点索引列表(整数列表)
|
|
184
|
+
|
|
185
|
+
example:
|
|
186
|
+
```python
|
|
187
|
+
poly_data = DmPolyData()
|
|
188
|
+
poly_data.insert_next_vert_cell([0, 1, 2])
|
|
189
|
+
```
|
|
190
|
+
"""
|
|
191
|
+
self._obj.InsertNextVertCell(point_indexes)
|
|
192
|
+
|
|
193
|
+
def insert_next_line_cell(self, point_indexes: list[int]) -> None:
|
|
194
|
+
"""
|
|
195
|
+
插入线段单元格
|
|
196
|
+
:param point_indexes: 点索引列表(整数列表)
|
|
197
|
+
|
|
198
|
+
example:
|
|
199
|
+
```python
|
|
200
|
+
poly_data = DmPolyData()
|
|
201
|
+
poly_data.insert_next_line_cell([0, 1, 2])
|
|
202
|
+
```
|
|
203
|
+
"""
|
|
204
|
+
self._obj.InsertNextLineCell(point_indexes)
|
|
205
|
+
|
|
206
|
+
def insert_next_poly_cell(self, point_indexes: list[int]) -> None:
|
|
207
|
+
"""
|
|
208
|
+
插入多边形单元格
|
|
209
|
+
:param point_indexes: 点索引列表(整数列表)
|
|
210
|
+
|
|
211
|
+
example:
|
|
212
|
+
```python
|
|
213
|
+
poly_data = DmPolyData()
|
|
214
|
+
poly_data.insert_next_poly_cell([0, 1, 2])
|
|
215
|
+
```
|
|
216
|
+
"""
|
|
217
|
+
self._obj.InsertNextPolyCell(point_indexes)
|
|
218
|
+
|
|
219
|
+
# ---------------------- 点操作 ----------------------
|
|
220
|
+
def insert_unique_point(self, point: DmDPoint) -> int:
|
|
221
|
+
"""
|
|
222
|
+
插入唯一的点(自动去重)
|
|
223
|
+
:param point: 待插入的点(DmDPoint实例)
|
|
224
|
+
:return: 点的唯一ID(整数)
|
|
225
|
+
|
|
226
|
+
example:
|
|
227
|
+
```python
|
|
228
|
+
poly_data = DmPolyData()
|
|
229
|
+
point_id = poly_data.insert_unique_point(DmDPoint(0.0, 0.0, 0.0))
|
|
230
|
+
```
|
|
231
|
+
"""
|
|
232
|
+
return self._obj.InsertUniquePoint(point._obj)
|
|
233
|
+
|
|
234
|
+
def get_point(self, point_id: int) -> DmDPoint:
|
|
235
|
+
"""
|
|
236
|
+
根据ID获取点
|
|
237
|
+
:param point_id: 点的唯一ID(整数)
|
|
238
|
+
:return: 对应的DmDPoint实例
|
|
239
|
+
|
|
240
|
+
example:
|
|
241
|
+
```python
|
|
242
|
+
poly_data = DmPolyData()
|
|
243
|
+
point_id = poly_data.insert_unique_point(DmDPoint(0.0, 0.0, 0.0))
|
|
244
|
+
point = poly_data.get_point(point_id)
|
|
245
|
+
```
|
|
246
|
+
"""
|
|
247
|
+
cpp_point = self._obj.GetPoint(point_id)
|
|
248
|
+
return DmDPoint._from_obj(cpp_point)
|
|
249
|
+
|
|
250
|
+
def set_dm_points(self, points: DmPoints) -> None:
|
|
251
|
+
"""
|
|
252
|
+
设置关联的点集合
|
|
253
|
+
:param points: DmPoints实例
|
|
254
|
+
|
|
255
|
+
example:
|
|
256
|
+
```python
|
|
257
|
+
poly_data = DmPolyData()
|
|
258
|
+
points = DmPoints()
|
|
259
|
+
poly_data.set_dm_points(points)
|
|
260
|
+
```
|
|
261
|
+
"""
|
|
262
|
+
self._obj.SetDmPoints(points._obj)
|
|
263
|
+
|
|
264
|
+
def get_dm_points(self) -> DmPoints:
|
|
265
|
+
"""
|
|
266
|
+
获取关联的点集合
|
|
267
|
+
:return: DmPoints实例
|
|
268
|
+
|
|
269
|
+
example:
|
|
270
|
+
```python
|
|
271
|
+
poly_data = DmPolyData()
|
|
272
|
+
points = DmPoints()
|
|
273
|
+
poly_data.set_dm_points(points)
|
|
274
|
+
dm_points = poly_data.get_dm_points()
|
|
275
|
+
```
|
|
276
|
+
"""
|
|
277
|
+
cpp_points = self._obj.GetDmPoints()
|
|
278
|
+
return DmPoints._from_obj(cpp_points)
|
|
279
|
+
|
|
280
|
+
# ---------------------- 多边形数据获取 ----------------------
|
|
281
|
+
def get_poly_cell(self, cell_index: int) -> list[int]:
|
|
282
|
+
"""
|
|
283
|
+
获取指定索引的多边形单元格的点索引
|
|
284
|
+
:param cell_index: 单元格索引(整数)
|
|
285
|
+
:return: 点索引列表(整数列表)
|
|
286
|
+
|
|
287
|
+
example:
|
|
288
|
+
```python
|
|
289
|
+
poly_data = DmPolyData()
|
|
290
|
+
cell_index = 0
|
|
291
|
+
point_indexes = poly_data.get_poly_cell(cell_index)
|
|
292
|
+
```
|
|
293
|
+
"""
|
|
294
|
+
return self._obj.GetPolyCell(cell_index)
|
|
295
|
+
|
|
296
|
+
# ---------------------- 提取多段线 ----------------------
|
|
297
|
+
def extract_polylines(self) -> list[DmDbPolyline]:
|
|
298
|
+
"""
|
|
299
|
+
提取多段线实体
|
|
300
|
+
:return: 多段线列表,每个元素为DmDbPolyline实例
|
|
301
|
+
|
|
302
|
+
example:
|
|
303
|
+
```python
|
|
304
|
+
poly_data = DmPolyData()
|
|
305
|
+
polylines = poly_data.extract_polylines()
|
|
306
|
+
```
|
|
307
|
+
"""
|
|
308
|
+
cpp_list = self._obj.ExtractPolylines()
|
|
309
|
+
return [DmDbPolyline._from_obj(item) for item in cpp_list]
|
|
310
|
+
|
|
311
|
+
# ---------------------- 字符串表示 ----------------------
|
|
312
|
+
def __repr__(self) -> str:
|
|
313
|
+
"""
|
|
314
|
+
字符串表示
|
|
315
|
+
:return: 多边形数据的标准字符串表示
|
|
316
|
+
"""
|
|
317
|
+
return self._obj.__repr__()
|
|
318
|
+
|
|
319
|
+
# ---------------------- 桥接方法 ----------------------
|
|
320
|
+
@classmethod
|
|
321
|
+
def _from_obj(cls, obj):
|
|
322
|
+
"""
|
|
323
|
+
原生对象创建封装实例
|
|
324
|
+
:param obj: 原生dmPolyData对象
|
|
325
|
+
:return: DmPolyData实例
|
|
326
|
+
"""
|
|
327
|
+
instance = cls.__new__(cls)
|
|
328
|
+
instance._obj = obj
|
|
329
|
+
return instance
|
|
330
|
+
|
|
331
|
+
#几何实体基类
|
|
332
|
+
class DmDbEntity:
|
|
333
|
+
"""所有实体对象都继承自该类,包括获取实体类型函数GetType、
|
|
334
|
+
将三维实体转换到dmPolyData对象函数ToPolyData、
|
|
335
|
+
将对象转换为三维实体对象函数ConvertToShell、
|
|
336
|
+
将对象转换为三维多段线对象函数ConvertToPolyline、
|
|
337
|
+
将对象转换为直线对象函数ConvertToLine、
|
|
338
|
+
将对象转换为点对象函数ConvertToPoint、
|
|
339
|
+
设置实体颜色函数SetColor、
|
|
340
|
+
获取实体类型名称函数GetEntityTypeName、
|
|
341
|
+
获取实体名称函数GetEntityName等
|
|
342
|
+
|
|
343
|
+
example:
|
|
344
|
+
```python
|
|
345
|
+
dmf = DmDbDatabase()
|
|
346
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
347
|
+
print("获取图层数量:",dmf.get_layers_count())
|
|
348
|
+
act_layer = dmf.get_active_layer()
|
|
349
|
+
|
|
350
|
+
layerCount = dmf.get_layers_count()
|
|
351
|
+
for i in range(layerCount):
|
|
352
|
+
layer = dmf.get_layer_by_index(i)
|
|
353
|
+
if layer is None:
|
|
354
|
+
continue
|
|
355
|
+
|
|
356
|
+
print("图层实体数量:",layer.get_entities_count())
|
|
357
|
+
|
|
358
|
+
layer.start_query_entity()
|
|
359
|
+
entity = layer.open_next_entity()
|
|
360
|
+
while entity is not None:
|
|
361
|
+
nType = entity.get_type()
|
|
362
|
+
#print("实体类型:",nType)
|
|
363
|
+
if nType == EntityType.ETT_POLYLINE:
|
|
364
|
+
print("实体类型名称:", entity.get_entity_type_name())
|
|
365
|
+
polydata = entity.to_poly_data()
|
|
366
|
+
print("获取多边形点集:",polydata.get_dm_points())
|
|
367
|
+
print("获取多边形包围盒:",polydata.get_bounds())
|
|
368
|
+
elif nType == EntityType.ETT_POINT:
|
|
369
|
+
print("实体类型名称:", entity.get_entity_type_name())
|
|
370
|
+
point = entity.convert_to_point().get_graph_data()
|
|
371
|
+
print(type(point))
|
|
372
|
+
print("获取点数据:",point)
|
|
373
|
+
elif nType == EntityType.ETT_LINE:
|
|
374
|
+
print("实体类型名称:", entity.get_entity_type_name())
|
|
375
|
+
line = entity.convert_to_line()
|
|
376
|
+
print(type(line))
|
|
377
|
+
print("获取线数据:",line)
|
|
378
|
+
entity.set_color(255,0,0)
|
|
379
|
+
entity = layer.open_next_entity()
|
|
380
|
+
```
|
|
381
|
+
"""
|
|
382
|
+
|
|
383
|
+
# def __init__(self):
|
|
384
|
+
# self._obj = None
|
|
385
|
+
|
|
386
|
+
|
|
387
|
+
@classmethod
|
|
388
|
+
def _from_obj(cls, obj):
|
|
389
|
+
"""
|
|
390
|
+
原生DmDbEntity对象创建封装实例
|
|
391
|
+
:param obj: 原生DmDbEntity对象(bind11封装后)
|
|
392
|
+
:return: DmDbEntity实例
|
|
393
|
+
"""
|
|
394
|
+
instance = cls.__new__(cls)
|
|
395
|
+
instance._obj = obj
|
|
396
|
+
return instance
|
|
397
|
+
|
|
398
|
+
def get_type(self) -> int:
|
|
399
|
+
"""
|
|
400
|
+
获取实体类型编码
|
|
401
|
+
:return: 实体类型的整数编码
|
|
402
|
+
"""
|
|
403
|
+
return self._obj.GetType()
|
|
404
|
+
|
|
405
|
+
def to_poly_data(self) -> DmPolyData:
|
|
406
|
+
"""
|
|
407
|
+
将实体转换为多边形数据
|
|
408
|
+
:return: 转换后的DmPolyData实例(需提前实现该类及_from_obj方法)
|
|
409
|
+
"""
|
|
410
|
+
cpp_result = self._obj.ToPolyData()
|
|
411
|
+
return DmPolyData._from_obj(cpp_result)
|
|
412
|
+
|
|
413
|
+
def convert_to_shell(self) -> DmDbShell:
|
|
414
|
+
"""
|
|
415
|
+
将实体转换为Shell对象
|
|
416
|
+
:return: 转换后的DmDbShell实例
|
|
417
|
+
"""
|
|
418
|
+
cpp_result = self._obj.ConvertToShell()
|
|
419
|
+
return DmDbShell._from_obj(cpp_result)
|
|
420
|
+
|
|
421
|
+
def convert_to_polyline(self) -> DmDbPolyline:
|
|
422
|
+
"""
|
|
423
|
+
将实体转换为多段线对象
|
|
424
|
+
:return: 转换后的DmDbPolyline实例
|
|
425
|
+
"""
|
|
426
|
+
cpp_result = self._obj.ConvertToPolyline()
|
|
427
|
+
return DmDbPolyline._from_obj(cpp_result)
|
|
428
|
+
|
|
429
|
+
def convert_to_line(self) -> DmDbLine:
|
|
430
|
+
"""
|
|
431
|
+
将实体转换为线对象
|
|
432
|
+
:return: 转换后的DmDbLine实例
|
|
433
|
+
"""
|
|
434
|
+
cpp_result = self._obj.ConvertToLine()
|
|
435
|
+
return DmDbLine._from_obj(cpp_result)
|
|
436
|
+
|
|
437
|
+
def convert_to_point(self) -> DmDbPoint:
|
|
438
|
+
"""
|
|
439
|
+
将实体转换为点对象
|
|
440
|
+
:return: 转换后的DmDbPoint实例
|
|
441
|
+
"""
|
|
442
|
+
cpp_result = self._obj.ConvertToPoint()
|
|
443
|
+
return DmDbPoint._from_obj(cpp_result)
|
|
444
|
+
|
|
445
|
+
def set_color(self, red: int, green: int, blue: int) -> None:
|
|
446
|
+
"""
|
|
447
|
+
设置实体颜色
|
|
448
|
+
:param red: 红色分量(0-255)
|
|
449
|
+
:param green: 绿色分量(0-255)
|
|
450
|
+
:param blue: 蓝色分量(0-255)
|
|
451
|
+
|
|
452
|
+
example:
|
|
453
|
+
```python
|
|
454
|
+
entity = DmDbEntity()
|
|
455
|
+
entity.set_color(255, 0, 0)
|
|
456
|
+
```
|
|
457
|
+
"""
|
|
458
|
+
self._obj.SetColor(red, green, blue)
|
|
459
|
+
|
|
460
|
+
def get_entity_type_name(self) -> str:
|
|
461
|
+
"""
|
|
462
|
+
获取实体类型名称(UTF-8编码)
|
|
463
|
+
:return: 实体类型名称字符串
|
|
464
|
+
|
|
465
|
+
example:
|
|
466
|
+
```python
|
|
467
|
+
entity = DmDbEntity()
|
|
468
|
+
entity_type_name = entity.get_entity_type_name()
|
|
469
|
+
```
|
|
470
|
+
"""
|
|
471
|
+
return self._obj.GetEntityTypeName()
|
|
472
|
+
|
|
473
|
+
def get_entity_name(self) -> str:
|
|
474
|
+
"""
|
|
475
|
+
获取实体名称(UTF-8编码)
|
|
476
|
+
:return: 实体名称字符串
|
|
477
|
+
|
|
478
|
+
example:
|
|
479
|
+
```python
|
|
480
|
+
entity = DmDbEntity()
|
|
481
|
+
entity_name = entity.get_entity_name()
|
|
482
|
+
```
|
|
483
|
+
"""
|
|
484
|
+
return self._obj.GetEntityName()
|
|
485
|
+
|
|
486
|
+
|
|
487
|
+
# 工作面实体
|
|
488
|
+
class DmDbWorkPlane:
|
|
489
|
+
def __init__(self):
|
|
490
|
+
"""
|
|
491
|
+
构造工作平面
|
|
492
|
+
"""
|
|
493
|
+
self._obj = Dm.dmDbWorkPlane()
|
|
494
|
+
|
|
495
|
+
def set_normal(self, normal: DmDPoint) -> None:
|
|
496
|
+
"""设置法向量"""
|
|
497
|
+
self._obj.SetNormal(normal._obj)
|
|
498
|
+
|
|
499
|
+
def set_origin(self, origin: DmDPoint) -> None:
|
|
500
|
+
"""设置原点"""
|
|
501
|
+
self._obj.SetOrigin(origin._obj)
|
|
502
|
+
|
|
503
|
+
def set_x_axis(self, x_axis: DmDPoint) -> None:
|
|
504
|
+
"""设置X轴方向"""
|
|
505
|
+
self._obj.SetXAxis(x_axis._obj)
|
|
506
|
+
|
|
507
|
+
def set_y_axis(self, y_axis: DmDPoint) -> None:
|
|
508
|
+
"""设置Y轴方向"""
|
|
509
|
+
self._obj.SetYAxis(y_axis._obj)
|
|
510
|
+
|
|
511
|
+
@classmethod
|
|
512
|
+
def _from_obj(cls, obj):
|
|
513
|
+
"""
|
|
514
|
+
原生dmDbWorkPlane对象创建封装实例
|
|
515
|
+
:param obj: 原生dmDbWorkPlane对象(bind11封装后)
|
|
516
|
+
:return: DmDbWorkPlane实例
|
|
517
|
+
"""
|
|
518
|
+
instance = cls.__new__(cls)
|
|
519
|
+
instance._obj = obj
|
|
520
|
+
return instance
|
|
521
|
+
|
|
522
|
+
|
|
523
|
+
class DmDbLayer:
|
|
524
|
+
def __init__(self):
|
|
525
|
+
self._obj = Dm.dmDbLayer()
|
|
526
|
+
|
|
527
|
+
def start_query_entity(self) -> None:
|
|
528
|
+
"""
|
|
529
|
+
开始查询实体
|
|
530
|
+
|
|
531
|
+
example:
|
|
532
|
+
```python
|
|
533
|
+
dmf = DmDbDatabase()
|
|
534
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
535
|
+
print("获取图层数量:",dmf.get_layers_count())
|
|
536
|
+
act_layer = dmf.get_active_layer()
|
|
537
|
+
|
|
538
|
+
layerCount = dmf.get_layers_count()
|
|
539
|
+
for i in range(layerCount):
|
|
540
|
+
layer = dmf.get_layer_by_index(i)
|
|
541
|
+
if layer is None:
|
|
542
|
+
continue
|
|
543
|
+
|
|
544
|
+
print("图层实体数量:",layer.get_entities_count())
|
|
545
|
+
|
|
546
|
+
layer.start_query_entity()
|
|
547
|
+
entity = layer.open_next_entity()
|
|
548
|
+
while entity is not None:
|
|
549
|
+
nType = entity.get_type()
|
|
550
|
+
#print("实体类型:",nType)
|
|
551
|
+
if nType == EntityType.ETT_POLYLINE:
|
|
552
|
+
···
|
|
553
|
+
entity = layer.open_next_entity()
|
|
554
|
+
```
|
|
555
|
+
"""
|
|
556
|
+
self._obj.StartQueryEntity()
|
|
557
|
+
|
|
558
|
+
def get_entities_count(self) -> int:
|
|
559
|
+
"""获取实体数量"""
|
|
560
|
+
return self._obj.GetEntitiesCount()
|
|
561
|
+
|
|
562
|
+
def open_next_entity(self) -> Optional[DmDbEntity]:
|
|
563
|
+
"""打开下一个实体,返回封装后的实体对象,无实体时返回 None"""
|
|
564
|
+
raw_entity = self._obj.OpenNextEntity()
|
|
565
|
+
if raw_entity:
|
|
566
|
+
return DmDbEntity._from_obj(raw_entity)
|
|
567
|
+
return None
|
|
568
|
+
|
|
569
|
+
def insert_entity(self, entity: Union[DmDbEntity, DmDbPolyline]) -> None:
|
|
570
|
+
"""插入实体,支持 DmDbEntity 和 dmDbPolyline 类型"""
|
|
571
|
+
self._obj.InsertEntity(entity._obj)
|
|
572
|
+
|
|
573
|
+
def insert_polyline(self, points: List[DmDPoint]) -> DmDbEntity:
|
|
574
|
+
"""插入多段线,返回封装后的实体对象"""
|
|
575
|
+
cpp_points = [p._obj for p in points]
|
|
576
|
+
raw_entity = self._obj.InsertPolyline(cpp_points)
|
|
577
|
+
return DmDbEntity._from_obj(raw_entity)
|
|
578
|
+
|
|
579
|
+
def insert_line(self, start: DmDPoint, end: DmDPoint) -> DmDbEntity:
|
|
580
|
+
"""插入直线,返回封装后的实体对象"""
|
|
581
|
+
raw_entity = self._obj.InsertLine(start._obj, end._obj)
|
|
582
|
+
return DmDbEntity._from_obj(raw_entity)
|
|
583
|
+
|
|
584
|
+
def set_work_plane_entity(self, work_plane: DmDbWorkPlane) -> None:
|
|
585
|
+
"""设置工作平面实体"""
|
|
586
|
+
self._obj.SetWorkPlaneEntity(work_plane._obj)
|
|
587
|
+
|
|
588
|
+
@classmethod
|
|
589
|
+
def _from_obj(cls, obj):
|
|
590
|
+
"""
|
|
591
|
+
原生dmDbLayer对象创建封装实例
|
|
592
|
+
:param obj: 原生dmDbLayer对象(bind11封装后)
|
|
593
|
+
:return: DmDbLayer实例
|
|
594
|
+
"""
|
|
595
|
+
instance = cls.__new__(cls)
|
|
596
|
+
instance._obj = obj
|
|
597
|
+
return instance
|
|
598
|
+
|
|
599
|
+
|
|
600
|
+
class DmDbDatabase:
|
|
601
|
+
"""
|
|
602
|
+
几何数据库
|
|
603
|
+
"""
|
|
604
|
+
|
|
605
|
+
def __init__(self):
|
|
606
|
+
# 初始化源扩展的核心对象,作为底层操作入口
|
|
607
|
+
self._db = Dm.dmDbDatabase()
|
|
608
|
+
|
|
609
|
+
def load(self, file_path: str) -> bool | int:
|
|
610
|
+
"""
|
|
611
|
+
加载本地数据库文件(底层调用源Load接口)
|
|
612
|
+
:param file_path: 数据库文件路径(UTF-8编码,底层已处理编码转换)
|
|
613
|
+
:return: 加载结果,成功返回True/0,失败返回False/错误码
|
|
614
|
+
|
|
615
|
+
example:
|
|
616
|
+
```python
|
|
617
|
+
dmf = DmDbDatabase()
|
|
618
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
619
|
+
print(db)
|
|
620
|
+
```
|
|
621
|
+
"""
|
|
622
|
+
if not isinstance(file_path, str) or not file_path.strip():
|
|
623
|
+
raise ValueError("文件路径不能为空字符串")
|
|
624
|
+
return self._db.Load(file_path)
|
|
625
|
+
|
|
626
|
+
def get_layers_count(self) -> int:
|
|
627
|
+
"""
|
|
628
|
+
获取数据库图层总数(底层调用源GetLayersCount接口)
|
|
629
|
+
:return: 非负整数,图层总数量
|
|
630
|
+
|
|
631
|
+
example:
|
|
632
|
+
```python
|
|
633
|
+
dmf = DmDbDatabase()
|
|
634
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
635
|
+
print("获取图层数量:",dmf.get_layers_count())
|
|
636
|
+
```
|
|
637
|
+
"""
|
|
638
|
+
return self._db.GetLayersCount()
|
|
639
|
+
|
|
640
|
+
def get_layer_by_index(self, layer_index: int) -> DmDbLayer | None:
|
|
641
|
+
"""
|
|
642
|
+
通过索引获取图层对象(底层调用源GetLayerFromIndex接口)
|
|
643
|
+
:param layer_index: 图层索引,从0开始
|
|
644
|
+
:return: 图层对象,索引无效时返回None
|
|
645
|
+
"""
|
|
646
|
+
if not isinstance(layer_index, int) or layer_index < 0:
|
|
647
|
+
raise ValueError("图层索引必须为非负整数")
|
|
648
|
+
cpp_result = self._db.GetLayerFromIndex(layer_index)
|
|
649
|
+
return DmDbLayer._from_obj(cpp_result)
|
|
650
|
+
|
|
651
|
+
def set_file_name(self, file_path: str) -> None:
|
|
652
|
+
"""
|
|
653
|
+
设置数据库文件路径(底层调用源SetFileName接口)
|
|
654
|
+
:param file_path: 数据库文件路径(UTF-8编码)
|
|
655
|
+
"""
|
|
656
|
+
if not isinstance(file_path, str) or not file_path.strip():
|
|
657
|
+
raise ValueError("文件路径不能为空字符串")
|
|
658
|
+
self._db.SetFileName(file_path)
|
|
659
|
+
|
|
660
|
+
def insert_layer(self, layer_name: str) -> DmDbLayer:
|
|
661
|
+
"""
|
|
662
|
+
插入新图层(底层调用源InsertLayer接口)
|
|
663
|
+
:param layer_name: 图层名称(UTF-8编码)
|
|
664
|
+
:return: 新创建的图层对象
|
|
665
|
+
|
|
666
|
+
example:
|
|
667
|
+
```python
|
|
668
|
+
dmf = DmDbDatabase()
|
|
669
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
670
|
+
layer = dmf.insert_layer("新图层")
|
|
671
|
+
print("插入新图层:",layer)
|
|
672
|
+
```
|
|
673
|
+
"""
|
|
674
|
+
if not isinstance(layer_name, str) or not layer_name.strip():
|
|
675
|
+
raise ValueError("图层名称不能为空字符串")
|
|
676
|
+
cpp_result = self._db.InsertLayer(layer_name.strip())
|
|
677
|
+
return DmDbLayer._from_obj(cpp_result)
|
|
678
|
+
|
|
679
|
+
def save(self, file_path: str | None = None) -> bool | int:
|
|
680
|
+
"""
|
|
681
|
+
保存数据库(底层调用源Save重载接口,自动适配无参/有参)
|
|
682
|
+
:param file_path: 可选保存路径,为None时保存到当前路径
|
|
683
|
+
:return: 保存结果,成功返回True/0,失败返回False/错误码
|
|
684
|
+
|
|
685
|
+
example:
|
|
686
|
+
```python
|
|
687
|
+
dmf = DmDbDatabase()
|
|
688
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
689
|
+
layer = dmf.insert_layer("新图层")
|
|
690
|
+
print("插入新图层:",layer)
|
|
691
|
+
dmf.save("E:/dassistant/tests/123_1.dmf")
|
|
692
|
+
```
|
|
693
|
+
"""
|
|
694
|
+
if file_path is None:
|
|
695
|
+
return self._db.Save()
|
|
696
|
+
if not isinstance(file_path, str) or not file_path.strip():
|
|
697
|
+
raise ValueError("保存路径不能为空字符串")
|
|
698
|
+
return self._db.Save(file_path)
|
|
699
|
+
|
|
700
|
+
def switch_to_local_storage(self) -> None:
|
|
701
|
+
"""切换到本地存储模式(底层调用源SetToLocalStorage接口)"""
|
|
702
|
+
self._db.SetToLocalStorage()
|
|
703
|
+
|
|
704
|
+
def get_active_layer(self) -> DmDbLayer | None:
|
|
705
|
+
"""
|
|
706
|
+
获取当前激活图层(底层调用源GetActiveLayer接口)
|
|
707
|
+
:return: 激活图层对象,无激活图层时返回None
|
|
708
|
+
|
|
709
|
+
example:
|
|
710
|
+
```python
|
|
711
|
+
dmf = DmDbDatabase()
|
|
712
|
+
db = dmf.load('E:/dassistant/tests/123.dmf')
|
|
713
|
+
layer = dmf.get_active_layer()
|
|
714
|
+
print("当前活动图层:",layer)
|
|
715
|
+
```
|
|
716
|
+
"""
|
|
717
|
+
cpp_result = self._db.GetActiveLayer()
|
|
718
|
+
return DmDbLayer._from_obj(cpp_result)
|
|
719
|
+
|
|
720
|
+
@staticmethod
|
|
721
|
+
def create_local_db() -> "DmDbDatabase":
|
|
722
|
+
"""
|
|
723
|
+
创建本地数据库(底层调用源CreateLocalDB静态接口)
|
|
724
|
+
:return: 新创建的数据库对象
|
|
725
|
+
"""
|
|
726
|
+
cpp_db = Dm.dmDbDatabase.CreateLocalDB()
|
|
727
|
+
return DmDbDatabase._from_obj(cpp_db)
|
|
728
|
+
|
|
729
|
+
def close_polyline(self) -> bool | int:
|
|
730
|
+
"""
|
|
731
|
+
闭合多段线(底层调用源ClosePolyline接口)
|
|
732
|
+
:return: 操作结果
|
|
733
|
+
"""
|
|
734
|
+
return self._db.ClosePolyline()
|
|
735
|
+
|
|
736
|
+
def set_color(self, red: int, green: int, blue: int) -> None:
|
|
737
|
+
"""
|
|
738
|
+
设置颜色(底层调用源SetColor接口)
|
|
739
|
+
:param red: 红色通道值(0-255)
|
|
740
|
+
:param green: 绿色通道值(0-255)
|
|
741
|
+
:param blue: 蓝色通道值(0-255)
|
|
742
|
+
"""
|
|
743
|
+
if not (0 <= red <= 255) or not (0 <= green <= 255) or not (0 <= blue <= 255):
|
|
744
|
+
raise ValueError("颜色值必须在0-255之间")
|
|
745
|
+
self._db.SetColor(red, green, blue)
|
|
746
|
+
|
|
747
|
+
def add_property(self, property_name: str, property_type: str) -> tuple[bool, str]:
|
|
748
|
+
"""
|
|
749
|
+
添加属性(底层调用源AddProperty接口)
|
|
750
|
+
:param property_name: 属性名称(UTF-8编码)
|
|
751
|
+
:param property_type: 属性类型(UTF-8编码)
|
|
752
|
+
:return: 操作结果(是否成功,提示信息)
|
|
753
|
+
"""
|
|
754
|
+
if not isinstance(property_name, str) or not property_name.strip():
|
|
755
|
+
raise ValueError("属性名称不能为空")
|
|
756
|
+
if not isinstance(property_type, str):
|
|
757
|
+
raise ValueError("属性类型必须为字符串")
|
|
758
|
+
return self._db.AddProperty(property_name, property_type)
|
|
759
|
+
|
|
760
|
+
@classmethod
|
|
761
|
+
def _from_obj(cls, obj):
|
|
762
|
+
"""
|
|
763
|
+
原生dmDbDatabase对象创建封装实例
|
|
764
|
+
:param obj: 原生dmDbDatabase对象(bind11封装后)
|
|
765
|
+
:return: DmDbDatabase实例
|
|
766
|
+
"""
|
|
767
|
+
instance = cls.__new__(cls)
|
|
768
|
+
instance._obj = obj
|
|
769
|
+
return instance
|
|
770
|
+
|
|
771
|
+
|
|
772
|
+
class DmDataTableRecord:
|
|
773
|
+
"""
|
|
774
|
+
数据表记录类
|
|
775
|
+
"""
|
|
776
|
+
|
|
777
|
+
# def __init__(self, record_obj: Dm.CDataTableRecord):
|
|
778
|
+
# self._obj = record_obj # 接收底层记录对象
|
|
779
|
+
|
|
780
|
+
@classmethod
|
|
781
|
+
def _from_obj(cls, obj):
|
|
782
|
+
"""
|
|
783
|
+
原生dmDataTableRecord对象创建封装实例
|
|
784
|
+
:param obj: 原生dmDataTableRecord对象(bind11封装后)
|
|
785
|
+
:return: DmDataTableRecord实例
|
|
786
|
+
"""
|
|
787
|
+
instance = cls.__new__(cls)
|
|
788
|
+
instance._obj = obj
|
|
789
|
+
return instance
|
|
790
|
+
|
|
791
|
+
def as_string(self, field_name: str) -> str:
|
|
792
|
+
"""
|
|
793
|
+
获取字段值(字符串形式)
|
|
794
|
+
:param field_name: UTF-8 编码的字段名
|
|
795
|
+
:return: 字段值字符串
|
|
796
|
+
"""
|
|
797
|
+
if not isinstance(field_name, str) or not field_name.strip():
|
|
798
|
+
raise ValueError("字段名不能为空字符串")
|
|
799
|
+
return self._obj.asString(field_name)
|
|
800
|
+
|
|
801
|
+
def as_double(self, field_name: str) -> float:
|
|
802
|
+
"""
|
|
803
|
+
获取字段值(浮点形式)
|
|
804
|
+
:param field_name: UTF-8 编码的字段名
|
|
805
|
+
:return: 字段值浮点数
|
|
806
|
+
"""
|
|
807
|
+
if not isinstance(field_name, str) or not field_name.strip():
|
|
808
|
+
raise ValueError("字段名不能为空字符串")
|
|
809
|
+
return self._obj.asDouble(field_name)
|
|
810
|
+
|
|
811
|
+
def set_value(self, field_name: str, value: str | float) -> None:
|
|
812
|
+
"""
|
|
813
|
+
设置字段值(支持字符串/浮点数)
|
|
814
|
+
:param field_name: UTF-8 编码的字段名
|
|
815
|
+
:param value: 字段值(字符串或浮点数)
|
|
816
|
+
"""
|
|
817
|
+
if not isinstance(field_name, str) or not field_name.strip():
|
|
818
|
+
raise ValueError("字段名不能为空字符串")
|
|
819
|
+
if isinstance(value, str):
|
|
820
|
+
self._obj.Set_Value(field_name, value)
|
|
821
|
+
elif isinstance(value, (int, float)):
|
|
822
|
+
self._obj.Set_Value(field_name, float(value))
|
|
823
|
+
else:
|
|
824
|
+
raise TypeError("字段值仅支持字符串或数字类型")
|
|
825
|
+
|
|
826
|
+
|
|
827
|
+
class DmDataTable:
|
|
828
|
+
"""
|
|
829
|
+
数据表 Python 二次封装类
|
|
830
|
+
"""
|
|
831
|
+
|
|
832
|
+
def __init__(self):
|
|
833
|
+
self._obj = Dm.CDataTable()
|
|
834
|
+
|
|
835
|
+
def load(self, file_path: str) -> bool | int:
|
|
836
|
+
"""
|
|
837
|
+
加载数据表文件
|
|
838
|
+
:param file_path: UTF-8 编码的数据表文件路径
|
|
839
|
+
:return: 加载结果(成功返回 True/0,失败返回 False/错误码)
|
|
840
|
+
|
|
841
|
+
example:
|
|
842
|
+
```python
|
|
843
|
+
dt = DmDataTable()
|
|
844
|
+
dt.load("E:/dassistant/tests/123.dmd")
|
|
845
|
+
print("字段总数:",dt.get_field_count())
|
|
846
|
+
```
|
|
847
|
+
"""
|
|
848
|
+
if not isinstance(file_path, str) or not file_path.strip():
|
|
849
|
+
raise ValueError("文件路径不能为空字符串")
|
|
850
|
+
return self._obj.Load(file_path)
|
|
851
|
+
|
|
852
|
+
def get_field_count(self) -> int:
|
|
853
|
+
"""获取字段总数"""
|
|
854
|
+
return self._obj.Get_Field_Count()
|
|
855
|
+
|
|
856
|
+
def get_record_count(self) -> int:
|
|
857
|
+
"""获取记录总数"""
|
|
858
|
+
return self._obj.Get_Record_Count()
|
|
859
|
+
|
|
860
|
+
def get_record_data(self, record_index: int) -> dict:
|
|
861
|
+
"""
|
|
862
|
+
通过索引获取单条记录的完整数据
|
|
863
|
+
:param record_index: 记录索引(从0开始)
|
|
864
|
+
:return: 记录数据字典,键为字段名,值为字段值
|
|
865
|
+
"""
|
|
866
|
+
return self._obj.Get_Record_Data(record_index)
|
|
867
|
+
|
|
868
|
+
def get_field_id(self, field_name: str) -> int:
|
|
869
|
+
"""
|
|
870
|
+
通过字段名获取字段ID
|
|
871
|
+
:param field_name: UTF-8 编码的字段名
|
|
872
|
+
:return: 字段ID
|
|
873
|
+
"""
|
|
874
|
+
if not isinstance(field_name, str) or not field_name.strip():
|
|
875
|
+
raise ValueError("字段名不能为空字符串")
|
|
876
|
+
return self._obj.Get_Field_Id(field_name)
|
|
877
|
+
|
|
878
|
+
def get_field_name(self, field_index: int) -> str:
|
|
879
|
+
"""
|
|
880
|
+
通过索引获取字段名
|
|
881
|
+
:param field_index: 字段索引(从0开始)
|
|
882
|
+
:return: UTF-8 编码的字段名
|
|
883
|
+
"""
|
|
884
|
+
# if not isinstance(field_index, int) or field_index < 0:
|
|
885
|
+
# raise ValueError("字段索引必须为非负整数")
|
|
886
|
+
# if field_index >= self.get_field_count():
|
|
887
|
+
# raise IndexError("字段索引超出范围")
|
|
888
|
+
return self._obj.Get_Field_Name(field_index)
|
|
889
|
+
|
|
890
|
+
def get_field_display_name(self, field_index: int) -> str:
|
|
891
|
+
"""
|
|
892
|
+
通过索引获取字段显示名
|
|
893
|
+
:param field_index: 字段索引(从0开始)
|
|
894
|
+
:return: UTF-8 编码的字段显示名
|
|
895
|
+
"""
|
|
896
|
+
# if not isinstance(field_index, int) or field_index < 0:
|
|
897
|
+
# raise ValueError("字段索引必须为非负整数")
|
|
898
|
+
# if field_index >= self.get_field_count():
|
|
899
|
+
# raise IndexError("字段索引超出范围")
|
|
900
|
+
return self._obj.Get_Field_DisplayName(field_index)
|
|
901
|
+
|
|
902
|
+
def get_field_type(self, field_index: int) -> int:
|
|
903
|
+
"""
|
|
904
|
+
通过索引获取字段类型
|
|
905
|
+
:param field_index: 字段索引(从0开始)
|
|
906
|
+
:return: 字段类型枚举值
|
|
907
|
+
"""
|
|
908
|
+
# if not isinstance(field_index, int) or field_index < 0:
|
|
909
|
+
# raise ValueError("字段索引必须为非负整数")
|
|
910
|
+
# if field_index >= self.get_field_count():
|
|
911
|
+
# raise IndexError("字段索引超出范围")
|
|
912
|
+
return self._obj.Get_Field_Type(field_index)
|
|
913
|
+
|
|
914
|
+
def get_record_from_index(self, record_index: int) -> DmDataTableRecord:
|
|
915
|
+
"""
|
|
916
|
+
通过索引获取原始记录对象
|
|
917
|
+
:param record_index: 记录索引(从0开始)
|
|
918
|
+
:return: 原始记录对象
|
|
919
|
+
"""
|
|
920
|
+
# if not isinstance(record_index, int) or record_index < 0:
|
|
921
|
+
# raise ValueError("记录索引必须为非负整数")
|
|
922
|
+
# if record_index >= self.get_record_count():
|
|
923
|
+
# raise IndexError("记录索引超出范围")
|
|
924
|
+
cpp_result = self._obj.Get_Record_From_Index(record_index)
|
|
925
|
+
return DmDataTableRecord._from_obj(cpp_result)
|
|
926
|
+
|
|
927
|
+
def get_record_count_by_condition(self, field_name: str, field_value: str) -> int:
|
|
928
|
+
"""
|
|
929
|
+
根据字段名和值筛选记录数量
|
|
930
|
+
:param field_name: UTF-8 编码的字段名
|
|
931
|
+
:param field_value: UTF-8 编码的字段值
|
|
932
|
+
:return: 符合条件的记录数量
|
|
933
|
+
"""
|
|
934
|
+
if not isinstance(field_name, str) or not field_name.strip():
|
|
935
|
+
raise ValueError("字段名不能为空字符串")
|
|
936
|
+
if not isinstance(field_value, str):
|
|
937
|
+
raise ValueError("字段值必须为字符串")
|
|
938
|
+
return self._obj.GetRecordCountByCondition(field_name, field_value)
|
|
939
|
+
|
|
940
|
+
def add_record(self) -> bool | int:
|
|
941
|
+
"""添加一条新记录"""
|
|
942
|
+
return self._obj.Add_Record()
|
|
943
|
+
|
|
944
|
+
def save(self) -> bool | int:
|
|
945
|
+
"""保存数据表"""
|
|
946
|
+
return self._obj.Save()
|
|
947
|
+
|
|
948
|
+
@classmethod
|
|
949
|
+
def _from_obj(cls, obj):
|
|
950
|
+
"""
|
|
951
|
+
原生dmDataTable对象创建封装实例
|
|
952
|
+
:param obj: 原生dmDataTable对象(bind11封装后)
|
|
953
|
+
:return: DmDataTable实例
|
|
954
|
+
"""
|
|
955
|
+
instance = cls.__new__(cls)
|
|
956
|
+
instance._obj = obj
|
|
957
|
+
return instance
|