2010年4月27日 星期二

SSRS render excel 怪事

有一張用SSRS2005做出來的表,在TABLE HEADER要依資料動態顯示不同的TITLE

在IE 瀏覽看來都很正常,但匯出到EXCEL 2003 時,發現TITLE後面多了一個空白,以致於匯出到EXCEL 2003後,表頭內的文字變成了二行,其中第二行是空白, 但匯出PDF和列印都是正常

必須手動在這個儲存格中,後面的空白刪掉,表頭才會顯示正常

因為匯出EXCEL 2003才有這個問題,而且匯出EXCEL 2007沒有這個問題, 所以一直以為是RDL render 的問題

由於表頭的值是依dataset 的某VARCHAR欄位動顯示出來的, 所以回頭去看TABLE內的欄位值時,也沒發現有任何空白存在.

直到, 用SQL LEN function去查看欄位的長度時,才發現,原本應該只有長度9的內容值,竟然變成10

光是用眼睛看,真的明明只有看到 9個中文字啊...

再查了一下,   select len(replace(orgnDescription,char(13),'')) from organization


原來欄位內容值最後面多了一個換行符號(當初這個資料是轉進來的)
執行更新語法後, update organization set orgnDescription = replace(orgnDescription,char(13),'')

再查詢報表,匯出EXCEL , 問題就解決了.

所以開發後,要測試,除了IE版本要比照人客的環境外,連OFFICE也得要一致才行啊

沒有留言:

張貼留言

自動記錄滑鼠點選操作

為了一個需求,需要人工去點選幾個滑鼠的點選行為,找了幾種工具,覺得GS Auto Clicker最實用,極符合我的需求,尤其是多個固定位置的button點擊,解決了一個很耗時間的工作。 最後設定完預設hotkey F8為啟用鍵,就可以開始自動做工了。再按F8結束工作。 GS Au...