网页资讯视频图片知道文库贴吧地图采购
进入贴吧全吧搜索

 
 
 
日一二三四五六
       
       
       
       
       
       

签到排名:今日本吧第个签到,

本吧因你更精彩,明天继续来努力!

本吧签到人数:0

一键签到
成为超级会员,使用一键签到
一键签到
本月漏签0次!
0
成为超级会员,赠送8张补签卡
如何使用?
点击日历上漏签日期,即可进行补签。
连续签到:天  累计签到:天
0
超级会员单次开通12个月以上,赠送连续签到卡3张
使用连续签到卡
02月25日漏签0天
vba吧 关注:17,093贴子:66,977
  • 看贴

  • 图片

  • 吧主推荐

  • 游戏

  • 28回复贴,共1页
<<返回vba吧
>0< 加载中...

求助:文本如何转表达式

  • 只看楼主
  • 收藏

  • 回复
  • 跟着南哥混3天饿9顿
  • 初涉江湖
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
有文本
str="张三<>张三 or 张三 = 李四"
用什么方法可以让str根据文本里面的内容,转变成true或者false


  • DwcCC
  • 人中龙凤
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
evaluate 我试了下不行。
最土的办法 就是 提取判断符。
判断符>.<.>=.<=.=,<>,and,or
然后分优先级。比如 and or 就低于 >,<等
然后把字符串按判断符号 分为 A 判断符 B
举个例子: “张三>张三 or 张三=张四”
根据规则 分为 张三>张三 判断符 张三=张四
然后做个 select case 判断符
根据判断符带入对应的判断符格式
A or b
如果出现错误,或者 A B 字符串没有判断符 或者 值不是False 或者 True
就递归 继续分解 A 或者B
挺麻烦的。。


2026-02-25 02:59:41
广告
不感兴趣
开通SVIP免广告
  • DwcCC
  • 人中龙凤
    11
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼


通过 程序向模块2的程序进行修改,这样就能通过系统来进行判断
模块1的程序
Public A As Boolean
Sub bbb()
Dim Fuhao As String
Fuhao = "2 = 2 and 1 > 3 "
With ThisWorkbook.VBProject.VBComponents("模块2").CodeModule
.DeleteLines 2
.InsertLines 2, "A= " & Fuhao
End With
Call test
Debug.Print A
End Sub
模块2的程序
Sub test()
A = 2 = 2 And 1 > 3
End Sub


  • 跟着南哥混3天饿9顿
  • 初涉江湖
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
实在没时间研究,主要是没电脑。我其实想要的是function,用来给别的方法提供返回值的。因为不单单要转化一个表达式,而是要转化很多个字符串表达式。比如,某个function zf转bds("表达式")能实现这个功能,那大体的意思就zf转bds("张三 =王五 or 李四")返回值为false。"张三 like 张* and *三"返回值为true。想写个类似SQL的查询方法,但不用sql。


  • 天涯望海小童鞋
  • 初涉江湖
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
这个应该不难吧,用正则给所有的字符串加上引号 ,然后ado+sql就可以执行字符串查询


  • 子夜魔城
  • 后起之秀
    7
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
我可以教你


  • 跟着南哥混3天饿9顿
  • 初涉江湖
    1
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
我突然想到,应该将文字转换成相应的码(数字类型),符号不变。就可以了系统带的函数是支持纯数字文本表达式的转换的


登录百度账号

扫二维码下载贴吧客户端

下载贴吧APP
看高清直播、视频!
  • 贴吧页面意见反馈
  • 违规贴吧举报反馈通道
  • 贴吧违规信息处理公示
  • 28回复贴,共1页
<<返回vba吧
分享到:
©2026 Baidu贴吧协议|隐私政策|吧主制度|意见反馈|网络谣言警示