DB.FilterStringRule 在 AsValueString() 上失败

DB.FilterStringRule on a AsValueString() Fails

我正在尝试创建一个 pyrevit 插件,它根据用户选择的元素的参数值过滤当前视图中的元素。这适用于字符串和双精度类型的参数。但是 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 一起使用,或者 AsValueString 是否有完全其他的规则,例如 DB.FilterAsValueStringRule?

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