2008年3月21日 星期五

檔案下載或開啟時出現亂碼檔名

常常發現,不管是用 IE 或 FireFox 下載檔案,出現的檔名是亂碼。
下面介紹一個屬性設定,可以試試。

Response.HeaderEncoding = System.Text.Encoding.GetEncoding("big5");

透過設定 HeaderEncoding之後,可以將這問題解決掉。

完整的程式如後:

string strpath = "檔案路徑";
Response.HeaderEncoding = System.Text.Encoding.GetEncoding("big5");
Response.AddHeader("content-disposition", "attachment;filename=" + "中文檔名");
Response.WriteFile(strpath);
Response.End();

Ref:http://blog.darkthread.net/blogs/darkthreadtw/archive/2007/09/05/kb-open-and-download-file-in-chinese-filename.aspx


Ref:http://blog.miniasp.com/post/2008/04/ASPNET-Force-Download-File-and-deal-with-Chinese-Filename-correctly.aspx

[補充 20110920]
參閱保哥[ASP.NET 如何設定強制下載檔案並正確處理中文檔名的問題]這一篇文章,可以正確處理簡繁問題,也提供了不同瀏覽器的處理,非常值得參考。

[補充 20120704]
另一種選擇。
UrlPathEncode 用於檔案下載出現亂碼的問題
http://paladinprogram.blogspot.tw/2012/07/urlpathencode.html

GridView 在Firefox

GridView會自動增加一個 rules="all" 的 HTML 標籤,在 IE 瀏覽器是正常,但在 FireFox 瀏覽器,則會出現黑色框線。

解決之道,在於 GridLines = none ,到 GridView 控制項,找到 GridLines 屬性,並將他設成 none 就可以。

2008年3月18日 星期二

在ASP.NET 取得目前瀏覽器的URL

假設網頁位址為 http://localhost/ProjMngWeb/close/close_Main.aspx?seqsn=543

string strAbsoluteUri = Request.Url.AbsoluteUri;

strAbsoluteUri 的內容則為 http://localhost/ProjMngWeb/close/close_Main.aspx?seqsn=543

string [] arraySegments = Request.Url.Segments;

arraySegments 的內容則為 ["/" , "ProjMngWeb/" , "close/" , "close_Main.aspx"] 共4個維度

Bind DropDownList - SortedList

要繫結 DropDownList,一般可以用 DataSet 來完成。除此之外,可以使用 ArrayList 直當作他的資料來源,但缺點是需要 DropDownList 的 DataTextField 與 DataValueField 是一致。如果 DataTextField 與 DataValueField 真的不一樣的情況發生時,就需要使用 HashTable,然而,HashTable並不提供排序,結果可能不是我們想要的。因此,推薦另一個 SortedList 物件。

SortedList hEnd = new SortedList();
hEnd.Add("A","1");
hEnd.Add("B","2");
hEnd.Add("C","3");

ddlTimeStart.DataSource = hEnd;
ddlTimeStart.DataTextField = "key";
ddlTimeStart.DataValueField = "value";
ddlTimeStart.DataBind();

C#在客戶端和服務端操作Excel文件

REF:\\http://www.wangchao.net.cn/bbsdetail_149286.html

 一、在客戶端把數據導入到Excel文件步驟

  1、創建Excel
application
對象,打開或生成Excel文件

  //服務端創建StringBuilder對象

  
System.Text.StringBuilder sb=new System .Text .StringBuilder ();

   //指定客戶端執行語言

  sb.Append
("<Script Language=VBScript>");

   sb.Append
("<!--\r\n");

   sb.Append
("dim xls\r\n");

   //創建Excel
application
對象

   sb.Append
("Set xls=CreateObject(\"Excel.Application\")\r\n");

   //打開Excel文件

  sb.Append ("xls.WorkBooks.Open(C:\\MyExcel.xls)\r\n");

  2、選定工作表,把數據導入到Excel

  //選定欲操作的Excel

  sb.Append
("xls.Sheets(1).Select\r\n");

  //获得要操作数据表的行、列数

   int rows=dt.Rows.Count,cols=dt.Columns.Count
;

   //按行列将数据写入Excel

   for (int
j=brow+1;j<brow+cols ;j++)

   for (int i=bcol;i<bcol+rows
;i++)

 
 
sb.Append ("xls.Sheets(1).Cells(" +(j-1) + "," + (i)
+ ")=\"" + dt.Rows[i-bcol][j-brow].ToString ().Replace ("\"","'") + "\"\r\n");


   3、显示Excel文件

   sb.Append ("xls.visible=true\r\n");

   4、釋放創建的Excel
application
對象

   sb.Append
("set xls=nothing\r\n");

   sb.Append
("-->");

   sb.Append
("</script>");

  5、將代碼寫到客戶端

  
this.Page.RegisterClientScriptBlock("",sb.ToString ());

  二、在服務端操作Excel文件

  服務端操作Excel文件,是把Excel文件看作數據庫,把Excel工作表當作數據表

  1、創建連接並打開連接

  protected
System.Data .OleDb.OleDbConnection dbcnn;

  cnnstr="Provider=Microsoft.Jet.OLEDB.4.0;Extended
Properties=\"Excel 8.0;HDR=Yes;\";Data Source=C:\\MyExcel.xls”;

  dbcnn=new
OleDbConnection (cnnstr);

  dbcnn.Open
();

  2、創建OleDbCommand對象用來操作Excel文件

  protected
System.Data .OleDb .OleDbCommand dbcmd;

   dbcmd=new
OleDbCommand();

  
dbcmd.Connection =dbcnn;

  3、操作Excel文件

   //获得要操作数据表的行、列数

   rows=dt.Rows.Count
;

  
cols=dt.Columns.Count-1 ;

   //按行列将数据写入Excel文件Sheet1工作表

   for(int i=0;i<rows;i++)

   {

   olestr="
insert into [Sheet1$] values(";

   for(int
j=0;j<cols;j++)

   olestr=olestr+"'"+dt.Rows[i][j].ToString
()+"',";

   olestr+="'"+Convert.ToDecimal
(dt.Rows[i][cols].ToString ())+"')";

  
dbcmd.CommandText =olestr;

  
dbcmd.ExecuteNonQuery ();

   }

  4、釋放OleDbCommand對象、關閉連接

  dbcmd.Dispose
();

   dbcnn.Close
();

  5、可操作的SQL語句

  //建立名為punchdate的工作表,並指明子段類型。

  //創建工作表好處是可指定子段類型,否則都以字符串導出

   CREATE TABLE
punchdate(mno char(5), punchNum float)

   //插入新數據

   Insert into
punchdate(mno,punchNum) values(‘09’,9000)

   //更新數據

   Update
punchdate set punchNum=8000 where mno=’09’

  6、不可操作的SQL語句

  Delete from
punchdate

  7、注意連接子串

  //HDR=Yes
説明工作表第一行為子段名

  
"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel
8.0;HDR=Yes;\";Data Source=C:\\MyExcel.xls”

  //HDR=No
説明工作表沒有含子段名的行

  "Provider=Microsoft.Jet.OLEDB.4.0;Extended
Properties=\"Excel 8.0;HDR=No;\";Data Source=C:\\MyExcel.xls”

  8、注意對Web.config的設置

  刪除以下項目

   <identity
impersonate="true" />

  
或者這樣設置


   <identity
impersonate="false" />

  三、兩種方法的優缺點

  

  操作Excel文件方法

  優點

  缺點

  客戶端

  數據導入到Excel文件時,很靈活,可將數據填入任意指定的存儲格,定位到任意位置

  1、在客戶端生成ActiveX控件,要將站點設置成可信站點或對IE進行安全設置(降低了IE的安全性)

  2、對調用的Excel模板文件,用戶要有權讀寫

  3、在客戶端寫Excel文件速度比較慢

  服務端

  1、對調用的Excel模板文件,只要ASP.NET有權讀寫即可

  2、在服務端寫Excel文件速度比較快

  3、不要對IE進行特別設置

  對操作的文件只能當作數據庫操作,不夠靈活

  四、流输出

  原理:把數據填充到
DataGrid
,然後把DataGrid内容放到一個輸出流裏面,並指定輸出流類型為
Excel

  System.IO .StringWriter
sw =new System.IO.StringWriter();//
字符串流

  System.Web
.UI .HtmlTextWriter hw =new System.Web.UI.HtmlTextWriter(sw);//html

流,用字符串流作參數

  dg.RenderControl(hw);//DataGrid
流變成字符串流。

  Response.ContentType
="application/vnd.ms-excel";//
定義輸出流類型為
excel
流。關鍵語句。

  Response.ContentEncoding=System.Text.Encoding.GetEncoding("Big5");//指定編碼類型為大五碼

  Response.Write(sw.ToString());//輸出流

  Response.End();//結束

2008年3月17日 星期一

使用智慧段落選取-不夠智慧[=白癡]

習慣用【樣式與格式】的方法撰寫 Word 之後,發現有需要更改顏色、對齊方式等需求時, Word 會自動將整份文件都套用剛剛的調整,但我要改的並不是全部啊!

這時,就要拿出摳男的看家本領,在死不要錢的Google上找到解法:

到 工具-選項-編輯-使用智慧段落選取,將打勾拿掉就可以了。

Ref: http://office.microsoft.com/zh-tw/word/HA102362181028.aspx

2008年3月11日 星期二

IE 與 FireFox 開窗 討論

IE 與 FireFox 開窗

經測試,FireFox目前是沒辦法用獨占視窗開啟的。


參考:
http://blog.blueshop.com.tw/ajun/archive/2006/08/29/36797.aspx

使用這種開窗方式,要在 aspx 頁面 或是 Master 頁面加上

<% Response.Expires = 0; %>
不讓IE儲存網頁,不然會讀不到最新版異動

VS2005 document.all.XXX.value 會失效 [在 firefox]

在VS2005在firefox使用 javascript 語法 document.all.XXX.value 時會失效,主要原因是 aspx頁面預設套用的 DOCTYPE html PUBLIC 如下:



這個定義比以前的

更為嚴格。

所以如果要讓程式正常執行,需要改採 document.getElementById,或是更換 DOCTYPE html PUBLIC

Code Snippet titled [Method Stub - Body] failed to load

VS2005:
如果进行override操作时,提示: Code Snippet titled [Method Stub - Body] failed to load. Verify that refactoring snippets are recognized in the Code Snippet Manager and that the snippet files are valid on disk. 那说明指 定的Code Snippet块无法找到,解决办法很简单,只要重新导入Code Snippet块就行了。找到并打开Code Snippet Manager(Ctrl + K,Ctrl + B),然后选择要操作的语言(C#),用Add按钮导入两个默认的文件夹:Refactoring和Visual C#,这两个文件夹一般会在VS2005安装目录下的,如:C:\Program Files\Microsoft Visual Studio 8\VC#\Snippets\1033 ,如果有这两个文件夹,则先删除然后再导入。

轉載自:
http://www.cnblogs.com/ttinfo/archive/2007/04/26/727784.html

2008年3月7日 星期五

文件已儲存,但因儲存空間不足

WORD 存檔出現的錯誤

"文件已儲存,但因儲存空間不足,導致語音辨識資料遺失,不錄音時請務必關閉麥克風,並檢查磁碟可用空間"

解法:
開WORD--工具--選項--儲存--內嵌語言資料,不勾選,按確定重新存一次

2008年3月5日 星期三

SQL將字串欄位轉為Table的方法

SQL裡,將字串欄位轉為Table的方法:


/* -- 傳入參數 -- */

declare @list nvarchar(4000)
declare @delimiter nchar(1)

set @list=@companyAll    -- 將@companyAll 改為待處理字串
set @delimiter='
'   -- 將 @delimiter 改為分隔符號

/* -- END -- */

create table #tmp ( listpos int IDENTITY(1, 1) NOT NULL,str varchar(4000),nstr nvarchar(2000))
DECLARE @pos int,
@textpos int,
@chunklen smallint,
@tmpstr nvarchar(4000),
@leftover nvarchar(4000),
@tmpval nvarchar(4000)

SET @textpos = 1
SET @leftover = ''

WHILE @textpos <= datalength(@list) / 2 BEGIN

SET @chunklen = 4000 - datalength(@leftover) / 2
SET @tmpstr = @leftover + substring(@list, @textpos, @chunklen)
SET @textpos = @textpos + @chunklen
SET @pos = charindex(@delimiter, @tmpstr)

WHILE @pos > 0
BEGIN
SET @tmpval = ltrim(rtrim(left(@tmpstr, @pos - 1)))
INSERT #tmp (str, nstr) VALUES(@tmpval, @tmpval)
SET @tmpstr = substring(@tmpstr, @pos + 1, len(@tmpstr))
SET @pos = charindex(@delimiter, @tmpstr)

END

SET @leftover = @tmpstr

END

INSERT #tmp(str, nstr)
VALUES (ltrim(rtrim(@leftover)), ltrim(rtrim(@leftover)))


/* 刪除空白資料筆數 */
delete #tmp where len([str])=0
select * from #tmp
/* 清除暫存 table */
drop table #tmp

PS:為何要用㊣來當作區隔,因為在我的現實案例中,逗號已經無法當作唯一辨識了,所以才會選擇㊣。當然,可以根據實際情況來選擇所要區隔的符號。