本页面介绍 SunvStation Python 脚本中选择集的初始化机制与清除操作。选择集是脚本操作地理对象的核心容器,掌握其初始化和清除方法对于编写稳定的数据处理脚本至关重要。
## 选择集基本概念
在 SunvStation 脚本环境中,存在两种类型的选择集:**脚本选择集**和**系统选择集**。脚本选择集由 `SSProcessManager` 在内存中维护,用于批量操作地理对象;系统选择集则是地图界面中当前选中的对象集合,直接影响地图显示效果。两者可以相互同步,但具有不同的生命周期和管理方式。
脚本选择集由两个核心列表组成:`selGeoList` 存储点、线、面对象,`selNoteList` 存储注记对象。这种分离设计便于对不同类型的地理对象进行差异化管理。
Sources: [PySSProcess.py](PySSProcess.py#L30-L50)
## 选择集的自动初始化
当导入 `sunvpy` 模块或创建 `SSProcessManager` 实例时,选择集会自动完成初始化。初始化过程不需要开发者手动干预,确保脚本一开始就拥有可用的选择集容器。
自动初始化包含以下步骤:获取当前工作空间实例、获取当前比例尺地图、创建地物和注记的空列表、初始化搜索助手、配置数据源和数据集列表。
```mermaid
flowchart LR
A[模块导入] --> B[创建 SSProcessManager 实例]
B --> C[获取工作空间 WorkSpace]
C --> D[获取当前地图 ScaleMap]
D --> E[初始化选择集容器]
E --> F[selGeoList = GeoBaseList]
E --> G[selNoteList = GeoBaseList]
E --> H[searchHelper = SSearchHelper]
H --> I[配置数据源和数据集]
I --> J[初始化完成,准备就绪]
```
Sources: [PySSProcess.py](PySSProcess.py#L50-L80)
**关键初始化代码**展示了这一过程的实现:
```python
# 脚本选择集容器(在 __init__ 中自动创建)
self.selGeoList = GeoBaseList() # 点线面对象列表
self.selNoteList = GeoBaseList() # 注记对象列表
self.searchHelper = SSearchHelper() # 搜索助手
```
Sources: [PySSProcess.py](PySSProcess.py#L56-L61)
## 清除脚本选择集
`clearSelection()` 方法用于清空脚本选择集中的所有对象。该方法会同时清除地物列表和注记列表,将选择集恢复到初始空状态。这个操作不会影响系统选择集(地图上显示的选中状态),也不会影响数据库中的原始数据。
```python
# 清除脚本选择集中的所有地物和注记
SSProcess.clearSelection()
```
Sources: [ssprocess_mixins/selection_mixin.py](ssprocess_mixins/selection_mixin.py#L38-L43)
**清除操作的实际效果**:调用 `clearSelection()` 后,`selGeoList` 和 `selNoteList` 都会变为空列表,后续的选择查询和遍历操作将基于空集进行。这是开启新一轮选择操作前的标准准备步骤。
## 清除选择条件
`clearSelectCondition()` 方法专门用于清除选择条件,而不影响选择集对象本身。选择条件由 `searchHelper` 内部维护,包含用于过滤查询的各种规则。清除条件后,新的查询将不再受之前设置条件的约束。
```python
# 清除之前设置的所有选择条件
SSProcess.clearSelectCondition()
```
Sources: [ssprocess_mixins/selection_mixin.py](ssprocess_mixins/selection_mixin.py#L45-L49)
选择条件与选择集对象的区别:选择条件是"筛选规则",选择集对象是"筛选结果"。`clearSelectCondition()` 清除规则,保留结果;`clearSelection()` 清除结果,保留规则。在实际脚本中,通常先清除条件,再设置新条件,最后执行查询。
## 清除系统选择集
`clearSysSelection()` 方法操作的是地图系统选择集,会移除地图界面上所有高亮显示的选中对象。这直接影响地图的视觉效果,使地图恢复到无选中状态。
```python
# 清除地图系统选择集(移除地图上的高亮显示)
SSProcess.clearSysSelection()
```
Sources: [ssprocess_mixins/selection_mixin.py](ssprocess_mixins/selection_mixin.py#L190-L193)
**脚本选择集与系统选择集的协同**:在需要完全重置选择状态的场景下,通常连续调用三种清除方法:先清除脚本选择集对象,再清除选择条件,最后清除系统选择集的高亮显示。
## 典型使用场景
### 场景一:开始新的查询操作
在执行新一轮数据查询前,需要重置选择集状态,确保不受到之前查询结果的干扰。
```mermaid
flowchart LR
A[开始新查询] --> B[clearSelection
清除脚本选择集]
B --> C[clearSelectCondition
清除选择条件]
C --> D[setSelectCondition
设置新条件]
D --> E[selectFilter
执行查询]
E --> F[获得新的选择集结果]
```
Sources: [PySSProcess.py](PySSProcess.py#L98-L106)
**完整示例代码**:
```python
# 准备阶段:清除旧的查询状态
SSProcess.clearSelection() # 清除之前的选择集对象
SSProcess.clearSelectCondition() # 清除之前的选择条件
# 设置新的查询条件
SSProcess.setSelectCondition("SSObj_Code", "==", "3103013")
# 执行查询
SSProcess.selectFilter()
# 获取查询结果
geo_count = SSProcess.getSelGeoCount()
print(f"查询到 {geo_count} 个地物对象")
```
Sources: [PySSProcess.py](PySSProcess.py#L98-L108)
### 场景二:脚本结束前的清理
在脚本执行结束时,清除所有选择状态,避免影响用户后续操作。
```python
# 批量处理完成后清理
# ... 数据处理逻辑 ...
SSProcess.clearSelection() # 清除脚本选择集
SSProcess.clearSysSelection() # 清除地图高亮显示
```
### 场景三:条件筛选后重试
当第一次查询结果不符合预期时,清除条件并重新设置筛选规则。
```python
# 第一次查询
SSProcess.clearSelectCondition()
SSProcess.setSelectCondition("SSObj_Type", "==", "LINE")
SSProcess.selectFilter()
if SSProcess.getSelGeoCount() == 0:
# 结果为空,尝试调整条件
SSProcess.clearSelectCondition()
SSProcess.setSelectCondition("SSObj_Type", "==", "AREA")
SSProcess.selectFilter()
```
## 三种清除方法的对比
下表总结了三种清除方法的适用场景和操作范围:
| 方法 | 操作对象 | 是否影响地图显示 | 典型使用场景 |
|------|---------|----------------|-------------|
| `clearSelection()` | 脚本选择集对象列表 | 否 | 开始新一轮查询前、脚本结束清理 |
| `clearSelectCondition()` | 搜索条件规则 | 否 | 更改查询条件前、重试查询时 |
| `clearSysSelection()` | 地图系统选择集 | 是 | 移除地图高亮、避免视觉干扰 |
Sources: [ssprocess_mixins/selection_mixin.py](ssprocess_mixins/selection_mixin.py#L38-L193)
## 选择集状态检查
在清除操作前后,可以使用查询方法验证选择集状态。
```python
# 清除前检查
print(f"清除前地物数量: {SSProcess.getSelGeoCount()}")
print(f"清除前注记数量: {SSProcess.getSelNoteCount()}")
# 执行清除
SSProcess.clearSelection()
# 清除后检查
print(f"清除后地物数量: {SSProcess.getSelGeoCount()}")
print(f"清除后注记数量: {SSProcess.getSelNoteCount()}")
```
Sources: [ssprocess_mixins/selection_mixin.py](ssprocess_mixins/selection_mixin.py#L195-L208)
## 完整工作流程示例
以下示例展示了一个完整的选择集使用周期:初始化、设置条件、查询、处理、清理。
```python
# 步骤 1:重置选择集状态(通常不需要手动初始化)
SSProcess.clearSelection()
SSProcess.clearSelectCondition()
# 步骤 2:设置查询条件
SSProcess.setSelectCondition("SSObj_LayerName", "==", "Default_A")
SSProcess.setSelectCondition("SSObj_Type", "==", "AREA")
# 步骤 3:执行过滤查询
SSProcess.selectFilter()
# 步骤 4:处理选择集对象
count = SSProcess.getSelGeoCount()
for i in range(count):
name = SSProcess.getSelGeoValue(i, "SSObj_Name")
print(f"对象 {i}: {name}")
# 步骤 5:清理选择状态
SSProcess.clearSelection()
SSProcess.clearSysSelection()
```
Sources: [PySSProcess.py](PySSProcess.py#L98-L140)
## 常见问题与注意事项
**问题一**:清除选择集后,地图上的对象还在吗?
**解答**:清除脚本选择集不会从地图或数据库中删除对象,只是从内存中的列表移除引用。要真正删除对象,需要调用删除对象的方法。
**问题二**:为什么需要分别清除对象和条件?
**解答**:这是为了提供更精细的控制。有时需要保留选择结果但更换查询条件,有时需要更换条件但保留部分结果。分离设计让脚本更灵活。
**问题三**:系统选择集和脚本选择集会自动同步吗?
**解答**:不会自动同步。需要使用 `updateSysSelection()` 方法手动同步,可以指定同步方向。
Sources: [ssprocess_mixins/selection_mixin.py](ssprocess_mixins/selection_mixin.py#L152-L176)
## 学习路径建议
掌握清除与初始化选择集是学习 SunvStation 脚本的基础。建议按照以下顺序继续学习:
1. **[设置选择条件](12-she-zhi-xuan-ze-tiao-jian)**:深入了解如何构建复杂的选择条件
2. **[执行过滤查询](13-zhi-xing-guo-lv-cha-xun)**:学习 `selectFilter()` 方法的详细用法
3. **[遍历选择集对象](14-bian-li-xuan-ze-ji-dui-xiang)**:掌握如何高效遍历和访问选择集中的对象
4. **[使用 SSProcess 管理选择集](4-shi-yong-ssprocess-guan-li-xuan-ze-ji)**:回到快速入门,了解更完整的选择集管理流程
通过循序渐进的学习,您将能够熟练运用选择集机制,高效完成地理数据的批量处理任务。