mengmou

知道要做什么,知道要怎样做,知道要怎样学习。

用户操作
[即时聊天] [发私信] [加为好友]
孟子
最近评论
文章分类
    收藏
      相册
      LinkedServer
      摄影
      存档
      订阅我的博客
      XML聚合  FeedSky

      原创 txt文件的简繁转换收藏

      新一篇: 动态解决执行exec时字符串不能超过8000的问题 | 旧一篇: 得到对象调用的其他对象,显示为树形结构

      --首先要实现字符串的简繁转换(作者:邹建)

      if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[f_GB2BIG]') and xtype in (N'FN', N'IF', N'TF'))
      drop function [dbo].[f_GB2BIG]
      GO

      --生成码表
      if exists (select * from dbo.sysobjects where id = object_id(N'[codetable]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
      drop table [codetable]
      GO

      declare @j nvarchar(4000),@f nvarchar(4000)
      select @j='皑蔼碍爱翱袄奥坝罢摆败颁办绊帮绑镑谤剥饱宝报鲍辈贝钡狈备惫绷笔毕毙币闭边编贬变辩辫标鳖别瘪濒滨宾摈饼并拨钵铂驳卜补财参蚕残惭惨灿苍舱仓沧厕侧册测层诧搀掺蝉馋谗缠铲产产阐颤场尝长偿肠厂畅钞车彻尘沉陈衬撑称惩诚骋痴迟驰耻齿炽冲冲虫宠畴踌筹绸丑橱厨锄雏础储触处传疮闯创锤纯绰辞词赐聪葱囱从丛凑蹿窜错达带贷担单郸掸胆惮诞弹当挡党荡档捣岛祷导盗灯邓敌涤递缔颠点垫电淀钓调迭谍叠钉顶锭订丢东动栋冻斗犊独读赌镀锻断缎兑队对吨顿钝夺堕鹅额讹恶饿儿尔饵贰发罚阀珐矾钒烦范贩饭访纺飞诽废费纷坟奋愤粪丰枫锋风疯冯缝讽凤肤辐抚辅赋复复负讣妇缚该钙盖干赶秆赣冈刚钢纲岗皋镐搁鸽阁铬个给龚宫巩贡钩沟构购够蛊顾剐关观馆惯贯广规硅归龟闺轨诡柜贵刽辊滚锅国过骇韩汉号阂鹤贺横轰鸿红后壶护沪户哗华画划话怀坏欢环还缓换唤痪焕涣黄谎挥辉毁贿秽会烩汇讳诲绘荤浑伙获货祸击机积饥讥鸡绩缉极辑级挤几蓟剂济计记际继纪夹荚颊贾钾价驾歼监坚笺间艰缄茧检碱硷拣捡简俭减荐槛鉴践贱见键舰剑饯渐溅涧将浆蒋桨奖讲酱胶浇骄娇搅铰矫侥脚饺缴绞轿较秸阶节茎鲸惊经颈静镜径痉竞净纠厩旧驹举据锯惧剧鹃绢杰洁结诫届紧锦仅谨进晋烬尽劲荆觉决诀绝钧军骏开凯颗壳课垦恳抠库裤夸块侩宽矿旷况亏岿窥馈溃扩阔蜡腊莱来赖蓝栏拦篮阑兰澜谰揽览懒缆烂滥捞劳涝乐镭垒类泪篱离里里鲤礼丽厉励砾历历沥隶俩联莲连镰怜涟帘敛脸链恋炼练粮凉两辆谅疗辽镣猎临邻鳞凛赁龄铃凌灵岭领馏刘龙聋咙笼垄拢陇楼娄搂篓芦卢颅庐炉掳卤虏鲁赂禄录陆驴吕铝侣屡缕虑滤绿峦挛孪滦乱抡轮伦仑沦纶论萝罗逻锣箩骡骆络妈玛码蚂马骂吗买麦卖迈脉瞒馒蛮满谩猫锚铆贸么么霉没镁门闷们锰梦谜弥觅幂绵缅庙灭悯闽鸣铭谬谋亩钠纳难挠脑恼闹馁内拟腻撵捻酿鸟聂啮镊镍柠狞宁拧泞钮纽脓浓农疟诺欧鸥殴呕沤盘庞赔喷鹏骗飘频贫苹凭评泼颇扑铺朴谱栖凄脐齐骑岂启气弃讫牵扦钎铅迁签谦钱钳潜浅谴堑枪呛墙蔷强抢锹桥乔侨翘窍窃钦亲寝轻氢倾顷请庆琼穷趋区躯驱龋颧权劝却鹊确让饶扰绕热韧认纫荣绒软锐闰润洒萨鳃赛三伞丧骚扫涩杀纱筛晒删闪陕赡缮伤赏烧绍赊摄慑设绅审婶肾渗声绳胜圣师狮湿诗尸时蚀实识驶势适释饰视试寿兽枢输书赎属术树竖数帅双谁税顺说硕烁丝饲耸怂颂讼诵擞苏诉肃虽随绥岁孙损笋缩琐锁獭挞抬态摊贪瘫滩坛谭谈叹汤烫涛绦讨腾誊锑题体屉条贴铁厅听烃铜统头秃图涂团颓蜕脱鸵驮驼椭洼袜弯湾顽万网韦违围为潍维苇伟伪纬谓卫温闻纹稳问瓮挝蜗涡窝卧呜钨乌污诬无芜吴坞雾务误锡牺袭习铣戏细虾辖峡侠狭厦吓锨鲜纤咸贤衔闲显险现献县馅羡宪线厢镶乡详响项萧嚣销晓啸蝎协挟携胁谐写泻谢锌衅兴汹锈绣虚嘘须许叙绪续轩悬选癣绚学勋询寻驯训讯逊压鸦鸭哑亚讶阉烟盐严颜阎艳厌砚彦谚验鸯杨扬疡阳痒养样瑶摇尧遥窑谣药爷页业叶医铱颐遗仪彝蚁艺亿忆义诣议谊译异绎荫阴银饮隐樱婴鹰应缨莹萤营荧蝇赢颖哟拥佣痈踊咏涌优忧邮铀犹游诱舆鱼渔娱与屿语吁御狱誉预驭鸳渊辕园员圆缘远愿约跃钥岳粤悦阅云郧匀陨运蕴酝晕韵杂灾载攒暂赞赃脏凿枣灶责择则泽贼赠扎札轧铡闸栅诈斋债毡盏斩辗崭栈战绽张涨帐账胀赵蛰辙锗这贞针侦诊镇阵挣睁狰争帧郑证织职执纸挚掷帜质滞钟钟终种肿众众诌轴皱昼骤猪诸诛烛瞩嘱贮铸筑驻专砖转赚桩庄装妆壮状锥赘坠缀谆着浊兹资渍踪综总纵邹诅组钻准为于布制采注轼迹家致'
            ,@f='皚藹礙愛翺襖奧壩罷擺敗頒辦絆幫綁鎊謗剝飽寶報鮑輩貝鋇狽備憊繃筆畢斃幣閉邊編貶變辯辮標鼈別癟瀕濱賓擯餅並撥缽鉑駁蔔補財參蠶殘慚慘燦蒼艙倉滄廁側冊測層詫攙摻蟬饞讒纏鏟産產闡顫場嘗長償腸廠暢鈔車徹塵沈陳襯撐稱懲誠騁癡遲馳恥齒熾沖衝蟲寵疇躊籌綢醜櫥廚鋤雛礎儲觸處傳瘡闖創錘純綽辭詞賜聰蔥囪從叢湊躥竄錯達帶貸擔單鄲撣膽憚誕彈當擋黨蕩檔搗島禱導盜燈鄧敵滌遞締顛點墊電澱釣調叠諜疊釘頂錠訂丟東動棟凍鬥犢獨讀賭鍍鍛斷緞兌隊對噸頓鈍奪墮鵝額訛惡餓兒爾餌貳發罰閥琺礬釩煩範販飯訪紡飛誹廢費紛墳奮憤糞豐楓鋒風瘋馮縫諷鳳膚輻撫輔賦複復負訃婦縛該鈣蓋幹趕稈贛岡剛鋼綱崗臯鎬擱鴿閣鉻個給龔宮鞏貢鈎溝構購夠蠱顧剮關觀館慣貫廣規矽歸龜閨軌詭櫃貴劊輥滾鍋國過駭韓漢號閡鶴賀橫轟鴻紅後壺護滬戶嘩華畫劃話懷壞歡環還緩換喚瘓煥渙黃謊揮輝毀賄穢會燴彙諱誨繪葷渾夥獲貨禍擊機積饑譏雞績緝極輯級擠幾薊劑濟計記際繼紀夾莢頰賈鉀價駕殲監堅箋間艱緘繭檢堿鹼揀撿簡儉減薦檻鑒踐賤見鍵艦劍餞漸濺澗將漿蔣槳獎講醬膠澆驕嬌攪鉸矯僥腳餃繳絞轎較稭階節莖鯨驚經頸靜鏡徑痙競淨糾廄舊駒舉據鋸懼劇鵑絹傑潔結誡屆緊錦僅謹進晉燼盡勁荊覺決訣絕鈞軍駿開凱顆殼課墾懇摳庫褲誇塊儈寬礦曠況虧巋窺饋潰擴闊蠟臘萊來賴藍欄攔籃闌蘭瀾讕攬覽懶纜爛濫撈勞澇樂鐳壘類淚籬離裏裡鯉禮麗厲勵礫曆歷瀝隸倆聯蓮連鐮憐漣簾斂臉鏈戀煉練糧涼兩輛諒療遼鐐獵臨鄰鱗凜賃齡鈴淩靈嶺領餾劉龍聾嚨籠壟攏隴樓婁摟簍蘆盧顱廬爐擄鹵虜魯賂祿錄陸驢呂鋁侶屢縷慮濾綠巒攣孿灤亂掄輪倫侖淪綸論蘿羅邏鑼籮騾駱絡媽瑪碼螞馬罵嗎買麥賣邁脈瞞饅蠻滿謾貓錨鉚貿麽麼黴沒鎂門悶們錳夢謎彌覓冪綿緬廟滅憫閩鳴銘謬謀畝鈉納難撓腦惱鬧餒內擬膩攆撚釀鳥聶齧鑷鎳檸獰甯擰濘鈕紐膿濃農瘧諾歐鷗毆嘔漚盤龐賠噴鵬騙飄頻貧蘋憑評潑頗撲鋪樸譜棲淒臍齊騎豈啓氣棄訖牽扡釺鉛遷簽謙錢鉗潛淺譴塹槍嗆牆薔強搶鍬橋喬僑翹竅竊欽親寢輕氫傾頃請慶瓊窮趨區軀驅齲顴權勸卻鵲確讓饒擾繞熱韌認紉榮絨軟銳閏潤灑薩鰓賽叁傘喪騷掃澀殺紗篩曬刪閃陝贍繕傷賞燒紹賒攝懾設紳審嬸腎滲聲繩勝聖師獅濕詩屍時蝕實識駛勢適釋飾視試壽獸樞輸書贖屬術樹豎數帥雙誰稅順說碩爍絲飼聳慫頌訟誦擻蘇訴肅雖隨綏歲孫損筍縮瑣鎖獺撻擡態攤貪癱灘壇譚談歎湯燙濤縧討騰謄銻題體屜條貼鐵廳聽烴銅統頭禿圖塗團頹蛻脫鴕馱駝橢窪襪彎灣頑萬網韋違圍爲濰維葦偉僞緯謂衛溫聞紋穩問甕撾蝸渦窩臥嗚鎢烏汙誣無蕪吳塢霧務誤錫犧襲習銑戲細蝦轄峽俠狹廈嚇鍁鮮纖鹹賢銜閑顯險現獻縣餡羨憲線廂鑲鄉詳響項蕭囂銷曉嘯蠍協挾攜脅諧寫瀉謝鋅釁興洶鏽繡虛噓須許敘緒續軒懸選癬絢學勳詢尋馴訓訊遜壓鴉鴨啞亞訝閹煙鹽嚴顔閻豔厭硯彥諺驗鴦楊揚瘍陽癢養樣瑤搖堯遙窯謠藥爺頁業葉醫銥頤遺儀彜蟻藝億憶義詣議誼譯異繹蔭陰銀飲隱櫻嬰鷹應纓瑩螢營熒蠅贏穎喲擁傭癰踴詠湧優憂郵鈾猶遊誘輿魚漁娛與嶼語籲禦獄譽預馭鴛淵轅園員圓緣遠願約躍鑰嶽粵悅閱雲鄖勻隕運蘊醞暈韻雜災載攢暫贊贓髒鑿棗竈責擇則澤賊贈紮劄軋鍘閘柵詐齋債氈盞斬輾嶄棧戰綻張漲帳賬脹趙蟄轍鍺這貞針偵診鎮陣掙睜猙爭幀鄭證織職執紙摯擲幟質滯鍾鐘終種腫衆眾謅軸皺晝驟豬諸誅燭矚囑貯鑄築駐專磚轉賺樁莊裝妝壯狀錐贅墜綴諄著濁茲資漬蹤綜總縱鄒詛組鑽準為於佈製採註軾跡傢緻'

      create table codetable(gb nchar(1),big nchar(1))

      select top 4000 id=identity(int,1,1) into #t from syscolumns a,syscolumns b

      insert codetable
      select substring(@j,id,1),substring(@f,id,1) from #t where id<=len(@j)

      drop table #t
      go

      /*--简繁转换函数

       利用编码对照表,实现 简体-->繁体,繁体-->简体 的转换
       注意,转换函数使用的是unicode编码

      --邹建 2004.07--*/

      /*--调用示例

       --转换为繁体
       select dbo.f_GB2BIG('我是中国人',1)

       --转换为简体
       select dbo.f_GB2BIG('我是中國人',0)
      --*/
      create function f_GB2BIG(
      @str nvarchar(4000), --要转换的字符串
      @toBIG bit  --转换标志,为1,表示 GB-->BIG,否则是 BIG-->GB
      )returns nvarchar(4000)
      as
      begin
       if @toBIG=1
        select @str=replace(@str,gb,big)
        from codetable
        where charindex(gb,@str)>0
       else
        select @str=replace(@str,big,gb)
        from codetable
        where charindex(big,@str)>0
       return(@str)
      end
      go

      select dbo.f_GB2BIG('国',1)
      /*
      -------

      (1 行受影响)

      */

      ---------------------------------------------------------------------------------------------------------------

      --然后实现文件的简繁转换,文件导入导出部分的代码摘自<中文版sql server 2000开发于管理实例>

      create proc p_e_gb2big @filename varchar(8000)
      as
      /*
       描述:
        将繁体txt文件翻译成一个放在同一目录下的简体文件。 
       版本:
        时间   修改人  操作
        2007年05月11日 mengmou 创建
       输入参数:
        @filename 文件地址,形如c:\test.txt
       临时表:
        以输入参数为名的临时表,用text格式存放文本文件
      */
      begin
       set nocount on
       --验证文件是否存在
       create table #(file_exists bit,file_is_dir bit,parent_dir_exists bit)
       insert # exec master..xp_fileexist @filename
       
       if not exists(select 1 from # where file_exists = 1)
       begin
        select '文件不存在!' as message
        return
       end
       drop table #
       
       --创建保存文件的表
       if exists(select 1 from sysobjects where id = object_id('['+@filename+']'))
        exec('drop table ['+@filename+']')
       exec('create table dbo.['+@filename+'](id int identity,img ntext)')
       
       --1. 将文件保存到上面的表中的处理
       --生成bcp实用工具处理用的格式文件
       declare @s nvarchar(4000)
       select @s='BCP "SELECT ''8.0'' UNION ALL SELECT ''1'' UNION ALL SELECT ''1 SQLCHAR 0 0 '
         +'''+CHAR(34)+''\0''+CHAR(34)+'' 2 img ''+CHAR(34)+CHAR(34)'+'" QUERYOUT c:\bcp.fmt /T /c'
       exec master..xp_cmdshell @s,no_output
       
       --运用上面生成的格式文件保存文件到数据库中
       set @s='BCP '+db_name()+'.dbo.['+@filename+'] IN '+@filename+' /T /f c:\bcp.fmt'
       exec master..xp_cmdshell @s
       
       --转换
       exec('
        declare @len int,@i int,@textptr binary(16),@insert_offset int,@delete_len int,@str nvarchar(4000)
        select @len = datalength(img)/2-1,@i = 0,@textptr = textptr(img) from ['+@filename+']
       
        while @i*4000 <= @len
        begin
         select @insert_offset = @i*4000,@delete_len = case when @insert_offset+4000 > @len then @len-@insert_offset+1 else 4000 end
          ,@str = dbo.f_gb2big(convert(nvarchar(4000),substring(img,@insert_offset+1,@delete_len)),0)
         from ['+@filename+']
         updatetext ['+@filename+'].img @textptr @insert_offset @delete_len @str
         set @i = @i + 1
        end
       ')
       
       --2. 将数据库中保存的文件数据提取出来,保存为磁盘上的文件
       select @s='BCP "SELECT ''8.0'' UNION ALL SELECT ''1'' UNION ALL SELECT ''1 SQLCHAR 0 0 '
         +'''+CHAR(34)+''\0''+CHAR(34)+'' 1 img ''+CHAR(34)+CHAR(34)" QUERYOUT c:\bcp.fmt /T /c'
       exec master..xp_cmdshell @s,no_output
       
       --运用上面生成的格式文件读取数据库中的数据保存为文件
       set @s='BCP "SELECT TOP 1 img FROM '+db_name()+'.dbo.['+@filename+'] " QUERYOUT '+@filename+'_gb2big.txt /T /f c:\bcp.fmt'
       exec master..xp_cmdshell @s
       
       exec master..xp_cmdshell 'del c:\bcp.fmt' ,no_output
       exec('drop table ['+@filename+']')
      end
      go

      发表于 @ 2007年05月26日 16:59:00|评论(loading...)|编辑

      新一篇: 动态解决执行exec时字符串不能超过8000的问题 | 旧一篇: 得到对象调用的其他对象,显示为树形结构

      评论:没有评论。

      发表评论  


      登录
      Csdn Blog version 3.1a
      Copyright © 孟子