設(shè)為首頁收藏本站Access中國

Office中國論壇/Access中國論壇

 找回密碼
 注冊(cè)

QQ登錄

只需一步,快速開始

12下一頁
返回列表 發(fā)新帖
查看: 7408|回復(fù): 14
打印 上一主題 下一主題

[模塊/函數(shù)] 【新手入門】之六:“悲歡離合總無情”——淺談Split和Join

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
1#
發(fā)表于 2012-8-1 22:01:16 | 只看該作者 回帖獎(jiǎng)勵(lì) |正序?yàn)g覽 |閱讀模式
引子:
    少年聽雨歌樓上,紅燭昏羅帳。壯年聽雨客舟中,江闊云低,斷雁叫西風(fēng)。
  而今聽雨僧廬下,鬢已星星也。悲歡離合總無情,一任階前點(diǎn)滴到天明。
    從青樓聽曲的少年,到失意落魄的壯年,再到淡然物外的中老年,古人蔣捷一曲《虞美人.聽雨》娓娓道出,雨依舊,心已老,個(gè)中辛酸,卻說與誰聽?人生終究是一場(chǎng)孤旅,不斷地得到,然后不斷地失去。“一任階前點(diǎn)滴到天明”,人生無常,“任”與不“任”,常是無補(bǔ)于事,惟看透悲歡離合,方能了解真諦。

    前段日子,有版友問及拆分短信息成若干條,并排列整齊而美之。此誠Access界中“悲歡離合”也,拆分為“離”,排列整齊,則需增空格以補(bǔ)齊,此為“合”。
    Access界“離合”早有成法:分:Split;合:Join。簡而言之,Split是根據(jù)標(biāo)識(shí)字符來分割字符串,分割后得到一個(gè)數(shù)組;而Join則按標(biāo)識(shí)字符將數(shù)組連成一個(gè)字符串。
    實(shí)例來自于《新開一貼:怎樣把收到的多條短信按每條一行寫入文本框中》附件加以修改,在此對(duì)bjcompass一并謝過。希望大家能藉此看透Access中的“悲歡離合”。

【新手入門】之一:If分支語句
【新手入門】之二:分支語句總結(jié)
【新手入門】之三:循環(huán)語句For
【新手入門】之四:循環(huán)語句Do和死循環(huán)
【新手入門】之五:公共變量與傳址過程、傳值過程
【新手入門】之六:“悲歡離合總無情”——淺談Split和Join
【新手入門】之七:嵌套與并列——再談If流程問題
【新手入門】之八:“連就連”——淺談“&”和“+”連接符的區(qū)別

【新手入門】之九:從百錢百雞談起——淺談“規(guī)劃求解”兼答lingjiang問
【新手入門】之十:書到用時(shí)方恨少——自定義菜單(Access 2003)的制作
【新手入門】之十一:淺談ADO之序言
【新手入門】之十二:淺談ADO之Connection
【新手入門】之十三:淺談ADO之Conmmand(上)
【新手入門】之十四:淺談ADO之Command(下)
【新手入門】之十五:淺談ADO之Recordset(上)
【新手入門】之十六:淺談ADO之Recordset(下)
【新手入門】之十七:淺談列表框的使用
【新手入門】之十八:雙擊列表框修改數(shù)據(jù)
【新手入門】之十九:從“書與女友恕不外借”談起——淺談“Bookmark”的使用
【新手入門】之二十:“書與書簽”——bookmark屬性答疑
【新手入門】之二十一:記錄集的“凌遲”——逐條導(dǎo)出記錄集

【新手進(jìn)階】之一:基礎(chǔ)算法(一)
【新手進(jìn)階】之二:基礎(chǔ)算法(二)
【新手進(jìn)階】之三:基礎(chǔ)算法(三)
【新手進(jìn)階】之四:基礎(chǔ)算法(四)
【新手進(jìn)階】之五:排序搜索(一)
【新手進(jìn)階】之六:排序搜索(二)
【新手進(jìn)階】之七:遞歸算法
【新手進(jìn)階】之八:冒泡排序
【新手進(jìn)階】之九:淺談不綁定數(shù)據(jù)源操作記錄
【新手進(jìn)階】之十:工作日的計(jì)算
【新手進(jìn)階】之十一:“庖丁解!焙汀凹o(jì)昌學(xué)射”——淺談表格式文本數(shù)據(jù)的導(dǎo)入
【新手進(jìn)階】之十二:從四腳騰空的奔馬談起——原來界面可以這樣設(shè)計(jì)
【新手進(jìn)階】之十三:Outlook風(fēng)格導(dǎo)航界面
【新手進(jìn)階】之十四:倉庫管理系統(tǒng)

本帖子中包含更多資源

您需要 登錄 才可以下載或查看,沒有帳號(hào)?注冊(cè)

x

本帖被以下淘專輯推薦:

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享分享 分享淘帖1 訂閱訂閱
15#
發(fā)表于 2023-12-11 22:43:41 | 只看該作者
謝謝分享
回復(fù)

使用道具 舉報(bào)

14#
發(fā)表于 2016-5-9 10:32:20 | 只看該作者
帖子已更新。修改了 函數(shù) 返回值 的數(shù)據(jù)類型,并貼上了 短信的原始內(nèi)容。
13#
發(fā)表于 2016-4-19 16:26:03 | 只看該作者
本帖最后由 wu8313 于 2016-5-9 10:30 編輯

1、使用自定義 sql 函數(shù) 也可以處理,編碼量會(huì)少一些。(我沒有寫用戶界面來呈現(xiàn)數(shù)據(jù))

2、我直接抄襲別人的函數(shù),稍微改動(dòng)了一下,原作者返回值為 int ,我只是改為 nvarchar(4000) 而已。

============================================================

IF  EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[fsplit_拆分短信]') AND type in (N'FN', N'IF', N'TF', N'FS', N'FT'))
DROP FUNCTION [dbo].[fsplit_拆分短信]
GO

--創(chuàng)建字符串分拆的函數(shù)
create function [dbo].[fsplit_拆分短信](
@str varchar(8000)        --要分拆的字符串
,@spli varchar(10)        --字符串分隔符
)
returns @T_原始短信內(nèi)容 table(被拆分的短信 nvarchar(4000))
as
begin
declare @i int,@splen int
select @splen=len(@spli)
,@i=charindex(@spli,@str)
while @i>0
begin
insert into @T_原始短信內(nèi)容 values(left(@str,@i-1))
select @str=substring(@str,@i+@splen,8000)
,@i=charindex(@spli,@str)
end
if @str<>'' insert into @T_原始短信內(nèi)容 values(@str)
return
end

GO

--調(diào)用
select [被拆分的短信] from dbo.fsplit_拆分短信
('13021123456#我們已經(jīng)完成了所有的工作,大家盡情的享受愉快的假期。#20120605083012#||'+
'14232345678#信息已經(jīng)收到。#20120506083134#||'+
'13126666666#祝賀少年管弦樂團(tuán)取得優(yōu)異成績,感謝輔導(dǎo)教師的努力。#20120605093012#||'+
'13888888888#近期暴雨頻繁,請(qǐng)各位員工出行注意安全。#20120605093412#','#||')

本帖子中包含更多資源

您需要 登錄 才可以下載或查看,沒有帳號(hào)?注冊(cè)

x
12#
發(fā)表于 2016-3-18 14:01:17 | 只看該作者
哈哈,ROYCH 和冬瓜有一拼  技術(shù)型加詩人
11#
發(fā)表于 2013-3-28 21:26:55 | 只看該作者
版主很會(huì)講故事。
10#
發(fā)表于 2012-8-31 08:34:29 | 只看該作者
文采不錯(cuò),ACCESS用的也在行
9#
發(fā)表于 2012-8-3 16:23:40 | 只看該作者
受教了
8#
發(fā)表于 2012-8-2 22:12:33 | 只看該作者
奇才也
7#
發(fā)表于 2012-8-2 17:44:50 | 只看該作者
人才,
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則

QQ|站長郵箱|小黑屋|手機(jī)版|Office中國/Access中國 ( 粵ICP備10043721號(hào)-1 )  

GMT+8, 2025-7-17 05:15 , Processed in 0.167500 second(s), 38 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回復(fù) 返回頂部 返回列表