加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 钦州站长网 (https://www.0777zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > Asp教程 > 正文

asp mysql like 变量,asp中轻松实现变量名-值变换_asp技巧

发布时间:2023-02-14 13:01:41 所属栏目:Asp教程 来源:
导读:  nhconch [原作]

  用过PHP的朋友都知道,PHP中变量的使用灵活方便,特别是能在字符串中方便实现变量名-值变换,使得整个PHP代码更显简洁优美。比如一条更新数据库的SQL语句只需写成:”update users
  nhconch [原作]
 
  用过PHP的朋友都知道,PHP中变量的使用灵活方便,特别是能在字符串中方便实现变量名-值变换,使得整个PHP代码更显简洁优美。比如一条更新数据库的SQL语句只需写成:”update users set password=$password, group=$group, name=$username where account=$account”,其中的$password、$group、$username、$account便会被实际的变量值替换,而在ASP中要实现相同的功能必须写成:”update useres set password=” & password & “,group=” & group & “,name=” & username & ” where account=” & account & “”,显得冗长难看。如果这是一条insert语言而且插入的字段内容很多的话ASP 变量,那么查看字段与values的对应关系将会是一个痛苦的过程。
 
  现在让我们看看如何在ASP实现类似的变量名-值变换。
 
  思路
 
  首先,必须有一个方法把需要用实际值替换的变量名与普通的文本区分出来;然后,把所有找到的变量名用它所代表的实际值替换掉。
 
  对于第一点可以通过正则表达式查找得到,这里我们不采用PHP的变量表示方式,而采用大托号{}作为变量名的边界符,字符串表示变为password={password},group={group}。
 
  第二点是变量名-值变换的关键,通过变量名得到变量值。查看ASP资料没有找到直接实现的方法,但有一个函数Execute引起我们的注意,从资料说明中可知Execute可以执行传入的有效的字符串作为代码执行同,这样只要编写一个小函数就可以实现我们的要示。核心代码为:
 
  function GetVar(var_name)
 
  Execute(“function get_value(): get_value=” & var_name & “: end function”)
 
  getvar=get_value()
 
  end function
 
  实现
 
  完整代码:
 
  function GetVar(var_name)
 
  Execute(“function get_value(): get_value=” & var_name & “: end function”)
 
  getvar=get_value()
 
  end function
 
  function Txt2Value(str, level)
 
  dim regEx, Matches, Result
 
  Set regEx = new RegExp
 
  select case level
 
  case 0 regEx.Pattern = “\{(\w+)\}” 变量名有效
 
  case 1 regEx.Pattern = “\{([\w+\-\*/\\=]+)\}” 变量名及运算符有效
 
  case 2 regEx.Pattern = “\{([\w\s]+)\}” 除换行符外的所有字符有效
 
  case else exit function
 
  end select
 
  regEx.Pattern = “\{(\w+)\}”
 
  regEx.IgnoreCase = true
 
  regEx.Global = true
 
  Set Matches = regEx.Execute(str)
 
  javascript获取asp的变量_asp include 变量_ASP 变量
 
  Result = str
 
  response.write Matches.Count
 
  For Each Match In Matches
 
  Result = Replace(Result, Match.Value, GetVar(Match.SubMatches(0)))
 
  Next
 
  set Matches = nothing
 
  set regEx = nothing
 
  Txt2Value = Result
 
  end function
 
  function Var2Value(var_name)
 
  Var2Value = Txt2Value(var_name, 0)
 
  end Function
 
  调用方法:
 
  Var2Value(“update users set password={password}, group={group}, name={username} where account={account}”
 
  Var2Value调用了Txt2Value,Txt2Value找出所有变量名交调用GetVar得到变量值并进行替换。实际上直接调用Txt2Value(str,1)还允许对字符串值进行四则运算。
 

(编辑:PHP编程网 - 钦州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章