- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章ASP 三层架构 Convert类实现代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
这个类主要解决在类型转换时,如果直接使用类型转换函数,会因为变量为空或者格式不对而导致程序报错,而这种报错在大多数情况下是允许的.例如要转换一个字符串变量为数字,如果变量为空,则一般需要自动返回0. 另外一个重要功能就是封装变量格式化操作,可以保持整个网站的输出格式统一,例如时间格式,货币格式等等. 日期和货币格式化的时候,极易遇到因空值报错的情况,一般都不得不写个预判断空值的逻辑,再格式化变量. 使用这个类负责类型转换和格式化输出后,就不用操心这些琐碎的细节了,可以让编程的心情得到大大改善啊. 还有些其他格式化功能,也加了进去,例如Convert.ToPer()是用来转换数字成百分数,Convert.FirstUppercase()用来做首字母大写...... 你可以根据自己的需要,随时扩展这个类,不要忘记了和大家分享哦. 有些基本的函数,如果随便写一写,基本可以凑合着用,但是遇到特殊情况,就要重新改写.比如我写的Convert.ToInt()方法,将变量转换为Integer. 最基本的操作,是判断一下是否为空,不为空就直接用Cint()就可以了. 但是遇到变量超出了范围,又得判断是否在Integer范围内,所以又写了一个私有方法IsOverflowInteger(),用于判断变量值是否为某一个范围内的数字.经过这样的处理,相信基本可以处理所有的情况了. 所以我想,Convert类中的已有方法还是会有不少需要改善的,大家如果有更好更完善的函数请发上来分享,让它形成ASP中最标准的变量处理的类,再不用依赖ASP中那些有限的功能了. 如下列举一些比较主要的方法,具体细节请看代码. 类型判断: Convert.IsInteger(ByVal Value) 判断是否整数,只允许0~9和-号 Convert.IsInt(ByVal Value) 判断是否int型,其下类似,不用解释了. Convert.IsLng(ByVal Value) Convert.IsDecimal(ByVal Value) Convert.IsSng(ByVal Value) Convert.IsDbl(ByVal Value) Convert.IsCur(ByVal Value) Convert.IsBln(ByVal Value) Convert.IsDat(ByVal Value) Convert.IsArr(ByVal Value) 类型转换: Convert.ToStr(ByVal Value) Convert.ToInt(ByVal Value) Convert.ToLng(ByVal Value) Convert.ToSng(ByVal Value) Convert.ToDbl(ByVal Value) Convert.ToBln(ByVal Value) Convert.ToCur(ByVal Value) Convert.ToDat(ByVal Value) 格式化: Convert.FormatDat(ByVal Value, ByVal vStyle) 日期格式化 Convert.FormatCur(ByVal Value,ByVal vDecimal) 货币格式化 Convert.FormatNum(ByVal Value,ByVal vDecimal) 数字格式化 其他格式化: Convert.ToPer(Byval value,Byval value0) 百分数,带% Convert.FirstUppercase(ByVal value) 首字母大写 Convert.SafeSql(ByVal value) 替换sql中的'为'' 代码如下: (我不会插入代码,不知道CSDN是怎么操作的,点插入代码就是一个<textarea>,而不是可以折叠代码的风格,向了解的朋友请教.) 。
复制代码代码如下
Class Con_Convert ' ******global message private i,j,value0,value1,value2 Private Sub Class_Initialize End Sub Private Sub Class_Terminate End Sub ' ============================================================================== ' Check Type, Return ture/false ' ============================================================================== Public Function IsStr(ByVal Value) IsStr=true End Function ' ****** check string if is Integer Public Function IsInteger(ByVal Value) if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then IsInteger=false else IsInteger = True value0=Trim(Value) For i = 1 To len(value0) If Asc(Mid(value0, i, 1))>= Asc("0") and Asc(Mid(value0, i, 1)) <= Asc("9") Then Else if Asc(Mid(value0, i, 1))= Asc("-") and i=1 then else IsInteger = false Exit For end if End If Next end if End Function ' ****** check if Value is in range of integer ' Only use in this class ' Value : ' vBound : max Private Function IsOverflowInteger(ByVal Value,ByVal vBound) if IsInteger(Value) and IsInteger(vBound) then IsOverflowInteger=false value0=trim(value) value1=trim(vBound) if IsOverflowInteger=false then 'delete 0 from left do while ( left(value0,1)="0" or left(value0,1)="-" ) value0=right(value0,len(value0)-1) loop do while ( left(value1,1)="0" or left(value1,1)="-" ) value1=right(value1,len(value1)-1) loop if len(value0)=len(value1) then for i=1 to len(value0) if Asc(mid(value0,i,1)) > Asc(mid(value1,i,1)) or Asc(mid(value0,i,1)) > Asc("9") or Asc(mid(value0,i,1)) < Asc("0") then IsOverflowInteger=true exit for end if next else if len(value0)>len(value1) then IsOverflowInteger=true end if end if end if else IsOverflowInteger=true end if End Function Public Function IsInt(ByVal Value) IsInt=true if left(trim(value),1)="-" then if IsOverflowInteger(trim(value),"-32768") then IsInt=false end if else if IsOverflowInteger(trim(value),"32767") then IsInt=false end if end if end function Public Function IsLng(ByVal Value) IsLng=true if left(trim(value),1)="-" then if IsOverflowInteger(trim(value),"-2147483648") then IsLng=false end if else if IsOverflowInteger(trim(value),"2147483647") then IsLng=false end if end if End Function ' ************************************** ' Decimal ' ************************************** ' ****** check string if is Decimal Private Function IsDecimal(ByVal Value) dim intDecimalCount intDecimalCount=0 if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then IsDecimal=false else IsDecimal = True value0=Trim(Value) For i = 1 To len(value0) If Asc(Mid(value0, i, 1))>= Asc("0") and Asc(Mid(value0, i, 1)) <= Asc("9") Then Else select case Asc(Mid(value0, i, 1)) case Asc("-") if i=1 then else IsDecimal = false Exit For end if case Asc(".") if intDecimalCount<2 then intDecimalCount=intDecimalCount + 1 else IsDecimal = false Exit For end if case else IsDecimal = false Exit For end select End If Next end if End Function ' ****** check if Value is in range of Decimal ' Only use in this class ' Value : ' vBound : Private Function IsOverflowDecimal(ByVal Value,ByVal vBound) if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) or Trim(vBound)="" or IsNull(vBound) or IsEmpty(vBound) then IsOverflowDecimal=true else end if End Function Public Function IsSng(ByVal Value) IsSng=IsDecimal(value) ' -340282300000000000000000000000000000000 ~ -0.000000000000000000000000000000000000000000001401298 ' 0.000000000000000000000000000000000000000000001401298 ~ 340282300000000000000000000000000000000 ' -3.402823 E38 ~ -1.401298 E-45 ' 1.401298 E-45 ~ 3.402823 E38 End Function Public Function IsDbl(ByVal Value) IsDbl=IsDecimal(value) ' -1.79769313486232 E308 ~ -4.94065645841247 E-324 ' 4.94065645841247 E-324 ~ 1.7976931348623 E308 End Function Public Function IsCur(ByVal Value) IsCur=IsDecimal(value) '-922337203685477.5808 ~ 922337203685477.5807 End Function Public Function IsBln(ByVal Value) if Value=true or Value=false or trim(Value)="1" or trim(Value)="0" then IsBln=true else IsBln=false end if End Function Public Function IsDat(ByVal Value) if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then IsDat=false else IsDat=IsDate(Value) end if End Function Public Function IsArr(ByVal Value) if Trim(Value)="" or IsNull(Value) or IsEmpty(Value) then IsArr=false else IsArr=IsArray(Value) end if End Function ' ============================================================================== ' Convert Type, Return value/initial value ' ============================================================================== Public Function ToStr(ByVal Value) ToStr=trim(Value) End Function Public Function ToInt(ByVal Value) if IsInt(Value) then ToInt=Cint(Value) else ToInt=0 end if End Function Public Function ToLng(ByVal Value) if IsLng(Value) then ToLng=clng(Value) else ToLng=0 end if End Function Public Function ToSng(ByVal Value) if IsSng(Value) then ToSng=cSng(Value) else ToSng=0 end if End Function Public Function ToDbl(ByVal Value) if IsDbl(Value) then ToDbl=cDbl(Value) else ToDbl=0 end if End Function Public Function ToBln(ByVal Value) if IsBln(Value) then ToBln=cbool(Value) else ToBln=false end if End Function ' ****** vDecimal : number of decimal places Public Function ToCur(ByVal Value) if IsCur(Value) then ToCur=ccur(Value) else ToCur=0 end if End Function ' ****** vType : format of date Public Function ToDat(ByVal Value) if IsDat(Value) then ToDat=cdate(value) else ToDat="" end if End Function ' ============================================================================== ' Format ' ============================================================================== ' ******************************************************* 'FormatDat 'vdate 'vStyle 0:2008-1-30 1:2008/1/30 2:1/30/2008 3:30/1/2008 4:30-JAN-2008 ' 10:2008-1 11:2008/1 12:1/2008 ' 22:JAN-2008 ' 30:2008-1-30 11:20:20 ' 40:2008-01-09 Public Function FormatDat(ByVal Value, ByVal vStyle) dim dateThis,intStyle dateThis=ToDat(Value) intStyle=ToInt(vStyle) if dateThis="" or isnull(dateThis) then FormatDat = "" else Dim arrMonthArray(12) arrMonthArray(1)="JAN" arrMonthArray(2)="FEB" arrMonthArray(3)="MAR" arrMonthArray(4)="APR" arrMonthArray(5)="MAY" arrMonthArray(6)="JUN" arrMonthArray(7)="JUL" arrMonthArray(8)="AUG" arrMonthArray(9)="SEP" arrMonthArray(10)="OCT" arrMonthArray(11)="NOV" arrMonthArray(12)="DEC" select case intStyle case 1 FormatDat=cstr(year(dateThis)) &"/"& cstr(month(dateThis)) &"/"& cstr(day(dateThis)) case 2 FormatDat= cstr(month(dateThis)) &"/"& cstr(day(dateThis)) &"/"& cstr(year(dateThis)) case 3 FormatDat= cstr(day(dateThis)) &"/"& cstr(month(dateThis)) &"/"& cstr(year(dateThis)) case 4 FormatDat= cstr(day(dateThis)) &"-"& arrMonthArray(month(dateThis)) &"-"& cstr(year(dateThis)) case 10 FormatDat=cstr(year(dateThis)) &"-"& cstr(month(dateThis)) case 11 FormatDat=cstr(year(dateThis)) &"/"& cstr(month(dateThis)) case 12 FormatDat= cstr(month(dateThis)) &"/"& cstr(year(dateThis)) case 22 FormatDat= arrMonthArray(month(dateThis)) &"-"& cstr(year(dateThis)) case 30 FormatDat= cstr(year(dateThis)) &"-"& cstr(month(dateThis)) &"-"& cstr(day(dateThis)) &" "& hour(dateThis) &":"& minute(dateThis) &":"& second(dateThis) case 40 FormatDat=cstr(year(dateThis)) &"-"& ZeroPad(cstr(month(dateThis)),2) &"-"& ZeroPad(cstr(day(dateThis)),2) case else FormatDat=cstr(year(dateThis)) &"-"& cstr(month(dateThis)) &"-"& cstr(day(dateThis)) end select end if End Function ' ************** 'FormatCur ' ************** Public Function FormatCur(ByVal Value,ByVal vDecimal) FormatCur=Formatcurrency(ToCur(Value),ToInt(vDecimal)) End Function Public Function FormatNum(ByVal Value,ByVal vDecimal) FormatNum=FormatNumber(ToDbl(Value),ToInt(vDecimal)) End Function ' ============================================================================== ' other format ' ============================================================================== Public Function ToPer(Byval value,Byval value0) if Convert.ToDbl(value0)<>0 then ToPer = me.FormatNum( Convert.ToDbl(value) / Convert.ToDbl(value0) * 100,2 ) & "% " else ToPer = "0.00%" end if End Function ' ****** value -> Value first code change to uppercase Public Function FirstUppercase(ByVal value) value0 = trim(value) if len(value0)=0 then FirstUppercase = "" else FirstUppercase = UCase(left(value0,1)) & right(value0,len(value0)-1) end if End Function Public Function SafeSql(ByVal value) SafeSql = replace(value,"'","''") End Function End Class 。
最后此篇关于ASP 三层架构 Convert类实现代码的文章就讲到这里了,如果你想了解更多关于ASP 三层架构 Convert类实现代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
是否可以简化在裸机上运行的这条链: 具有随时间变化的副本数的 StatefulSet 服务 使用 proxy-next-upstream: "error http_502 timeout invali
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我需要为应用程序制定架构。它专为销售产品而设计。 系统每天将接受大约 30-40k 的新产品。它将导致在表 product 中创建新记录。 系统应保留价格历史记录。用户应该能够看到产品 A 的价格在去
我需要一些帮助来理解 PHP 的内部工作原理。 还记得,在过去,我们曾经写过 TSR(Terminate and stay resident)例程(pre-windows 时代)吗?一旦该程序被执行,
1.Nginx 基础架构 nginx 启动后以 daemon 形式在后台运行,后台进程包含一个 master 进程和多个 worker 进程。如下图所示: master与
本文深入探讨了Kubernetes(K8s)的关键方面,包括其架构、容器编排、网络与存储管理、安全与合规、高可用性、灾难恢复以及监控与日志系统。 关注【TechLeadCloud】,
我知道 CNN 的工作原理,包括每一层的用途(Dropout、Pooling 等)。但是,在为新数据集设计 CNN 时,我不知道要使用多少个 Conv-Relu-Pool 层,在最终获得输出之前我应该
在基于 REST 的架构中,资源和方法之间有什么区别。有吗? 最佳答案 资源是您的应用程序定义的东西;它们与物体非常相似。方法是 HTTP 动词之一,例如 GET、POST、PUT、DELETE。它们
我想用 oneOf仅在 xyType 的值上不同的模式属性(property)。我想要其中两个:一个是 xyType设置为 "1"第二个在哪里xyType是 任何其他值 .这可以使用 json 模式完
寻求 PHP 架构师的建议! 我对 PHP 不是很熟悉,但已经接管了一个用该语言编写的大型分析包的维护工作。该架构旨在将报告的数据读取到大型键/值数组中,这些数组通过各种解析模块传递,以提取每个模块已
这些存在吗? 多年来,我一直是大型强类型面向对象语言(Java 和 C#)的奴隶,并且是 Martin Fowler 及其同类的信徒。 Javascript,由于它的松散类型和函数性质,似乎不适合我习
我已经阅读了 Manning 的 Big Data Lambda Architecture ( http://www.manning.com/marz/BD_meap_ch01.pdf ),但仍然无法
在过去的几年里,我做了相当多的 iOS 开发,所以我非常熟悉 iOS 架构和应用程序设计(一切都是一个 ViewController,您可以将其推送、弹出或粘贴到选项卡栏中)。我最近开始探索正确的 M
我有以下应用程序,我在其中循环一些数据并显示它。 {{thing.title}} {{thing.description}}
昨天我和我的伙伴讨论了我正在开发的这个电子购物网站的架构。请注意,我为此使用 ASP.NET。他非常惊讶地发现我没有将添加到购物车的项目保留在 ArrayList 或其他通用列表中,而是使用 LINQ
我正在使用在 tridion 蓝图层次结构中处于较低位置的出版物。从蓝图中较高级别的出版物继承的一些内容和模式不适合我的出版物,并且永远不会被我的出版物使用。 我将跟进添加这些项目的内部团队,并尝试说
我目前已经在 Cassandra 中设计了一个架构,但我想知道是否有更好的方法来做事情。基本上,问题在于大多数(如果不是全部)读取都是动态的。我构建了一个分段系统作为应用程序服务,读取动态自定义查询(
我正在按照 documentation 中给出的 icingaweb UI v 2.0 布局执行在服务器上设置 icinga 的步骤。 。我成功进入设置页面,该页面要求您输入 token ,然后按照步
我必须保存来自不同社交媒体的用户的不同个人资料。例如用户可能有 1 个 Facebook 和 2 个 Twitter 个人资料。如果我保存每个配置文件它作为新文档插入不同的集合中,例如 faceboo
我的团队使用 Puppet 架构,该架构目前可在多个环境(流浪者、暂存、生产)中容纳单个应用程序。 我们现在想要扩展此设置的范围以支持其他应用程序。他们中的许多人将使用我们已经定义的现有模块的子集,而
我是一名优秀的程序员,十分优秀!