我创建了一个矩阵报告。我有一个专栏'模型'和价值观(经典,半经典,大,双,全,国王,女王)。要求是将这些值拆分为列。
我为此创建了列组并写了这样的表达式:
=Switch(Fields!model.Value = " ", "NULL" ,
Fields!model.Value = "classic", 1,
Fields!model.Value = "semi classic", 1,
Fields!model.Value = "Grand", 1,
Fields!model.Value = "Twin", 1,
Fields!model.Value = "Full", 1,
Fields!model.Value = "King", 1,
Fields!model.Value = "Queen", 1
)
现在我必须将这些模型按特定顺序排序(不是在A-Z或Z-A中)。
订单应该是:双胞胎,Grand,Queen,Classic,Full,半经典,国王
有人可以帮助我扭曲表达方式或某些属性。
由于
答案 0 :(得分:4)
你已经写了大部分内容。如果你将Sorting设置为这个表达式,我想你会得到你想要的。
=Switch(
Fields!model.Value = " ", 100 ,
Fields!model.Value = "classic", 4,
Fields!model.Value = "semi classic", 6,
Fields!model.Value = "Grand", 2,
Fields!model.Value = "Twin", 1,
Fields!model.Value = "Full", 5,
Fields!model.Value = "King", 7,
Fields!model.Value = "Queen", 3)
使用上面的表达式对排序进行排序。不要将其用于单元格的值。为此使用您的初始值。
顺便说一句,看起来您的原始switch语句有一些可以消除的冗余。对于未在交换机中列出的任何值,这会有所不同,但其他方面会给您相同的结果:
=IIF(Fields!model.Value = " ", "NULL" , 1)