AsValueString上的DB.FilterStringRule失败

问题描述

我正在尝试创建一个pyrevit插件,该插件根据用户选择的元素的参数值过滤当前视图中的元素。这对于s​​tring和double kind的参数很好用。但是AsValueString()在DB.FilterStringRule中失败,可能是因为在python中将AsValueString类型转换为字符串类型时单元信息丢失了。我在下面添加了相关代码

target_parameter_value = ele.Parameter[target_parameter].AsValueString()# As value strings got converted to strings
param_id = DB.ElementId(target_parameter)
param_prov = DB.ParameterValueProvider(param_id)
param_equality = DB.FilterStringEquals() # equality class for string
value_rule = DB.FilterStringRule(param_prov,param_equality,target_parameter_value,True)
param_filter = DB.ElementParameterFilter(value_rule)
    
elements = DB.FilteredElementCollector(doc)\
           .OfCategory(target_category)\
           .WhereElementIsNotElementType()\
           .WherePasses(param_filter)\
           .toElementIds() # select category based on the rule

AsValueString是否可以与DB.FilterStringRule一起使用,还是有其他完全替代的规则,例如DB.FilterasValueStringRule?

解决方法

您完全不能将AsValueStringFilterStringRule一起使用。后者与原始Revit数据库值进行交互。前者将原始Revit数据库值转换为用户可见的显示字符串。请改用Parameter值访问器来读取原始数据库值: