VC6.0下配置boost库使用正则表达式

本文介绍了如何配置Boost库中的正则表达式模块,并提供了SDK和MFC下的测试示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  上网baidu一下,发现支持正则的库还真不少,大概有以下几种:boost,GNU,VC7带的ATL中的和微软发布的greta。

  网上的朋友对boost评价不错,决定就使用是它了!

  1、接下来的就是下载boost库,网上很好找。我下载的是压缩包,20多M,解压后将近100多M。

  我解压的目录是D:\boost

  2、然后是编译,我只要支持正则表达式就可以,因此只需要编译D:\boost\libs\regex\build目录下的文件。据说全部编译要花将近2个小时,没有验证过,在我家里的机器上编译正则表达式部分只用了不到5分钟。

  网上介绍的如何编译最多的一篇文章是“VC利用boost库解析正则表达式”,如果有人能根据这篇文章编译成功不妨告诉小弟一声……

  以下是我的操作:

  在“运行”里输入“cmd”,打开命令提示符;

  输入命令“cd D:\boost\libs\regex\build”//设置当前目录

  输入命令“D:”//转到当前目录

  接下来是很关键的一步:

  很多文章是这样说的“输入 nmake -fvc6.mak”

  但是出现了“'nmake' 不是内部或外部命令,也不是可运行的程序或批处理文件。”的错误提示。

  然后你就会拼命查找原因,结果又有文章上说是环境变量没配置好,然后给出一堆“set”。

  也有的文章说是运行一下visual studio安装目录下的VC98\Bin\VCVARS32.BAT文件就OK了。

  你按照文章作者的方法做的,结果发现问题依旧!

  以上说法都是正确的,但是说得都不是很完整,出现错误提示的根本原因就是环境变量没配置好,不识别nmake命令,配置过jdk的朋友就很容易明白。如果按照作者的要求搞一堆“set”,未免大题小作了吧,因为我们只需要用一次'nmake' 就可以解决问题了。

  VCVARS32.BAT正式配置环境变量的批处理文件,但是配置的参数只在当前窗口有效,也就是说当你双击运行后窗口关闭,环境变量已经没有了。

  于是我用了以下方法:

  把VCVARS32.BAT文件用鼠标拖到打开的cmd窗口("D:\Program Files\Microsoft Visual Studio\VC98\Bin\VCVARS32.BAT"),然后回车。

  输入命令“nmake -fvc6.mak”

  等待几分钟,OK了!,D:\boost\libs\regex\build多了一个vc6的文件夹,里面是很多lib和dll文件。

  3、到此资源已经准备好了,下面要做的工作是配置VC6.0,使它编译使时候能找到正则库。

  把vc6下的所有lib和dll文件拷贝到Visual Studio安装目录下的VC98\boostRex(boostRex是我自己建的)

  然后打开vc6.0,选择“Tools->Options->Directories->Include files”,加入一行“D:\BOOST”

  选择“Tools->Options->Directories->Library file”,加入一行“C:\PROGRAM FILES\MICROSOFT VISUAL STUDIO\VC98\BOOSTREX”(彩色部分是我的Visual Studio安装目录)

  配置也OK了!

  4、编写程序测试

  SDK下的测试:

#include "stdafx.h"
#include <cstdlib>
#include <stdlib.h>
#include <boost/regex.hpp>
#include <string>
#include <iostream>

using namespace std;
using namespace boost;

regex expression("^select ([a-zA-Z]*) from ([a-zA-Z]*)");
bjbjz.howbk.com;
shbjz.howbk.com;
tjbjz.howbk.com;
cqbjz.howbk.com;
hebbjz.howbk.com;
jlbjz.howbk.com;
sybjz.howbk.com;
dlbjz.howbk.com;
asbjz.howbk.com;
jnbjz.howbk.com;
qdrbjz.howbk.com;
zbbjz.howbk.com;
dybjz.howbk.com;
ytbjz.howbk.com;
wfbjz.howbk.com;
tybjz.howbk.com;
xabjz.howbk.com;
sjzbjz.howbk.com;
tsbjz.howbk.com;
qhdbjzz.howbk.com;
lybjz.howbk.com;
zzbjz.howbk.com;
whbjz.howbk.com;
csbjz.howbk.com;
wxbjz.howbk.com;
njbjzz.howbk.com;
lczem.howbk.com;
wzme.howbk.com;
labjz.howbk.com;
czme.howbk.com;
lfbjz.howbk.com;
whmi.howbk.com;
qdmt.howbk.com;
ycme.howbk.com;
ylme.howbk.com;
csme.howbk.com;
hebjz.howbk.com;
ncme.howbk.com;
ykme.howbk.com;
xyme.howbk.com;
xmme.howbk.com;
fzme.howbk.com;
wzcm.howbk.com;
sxcm.howbk.com;
hzme.howbk.com;
jnme.howbk.com;
dyme.howbk.com;
hfme.howbk.com;
hfme.howbk.com;
czce.howbk.com;
czmt.howbk.com;
zzmi.howbk.com;
jcbjz.howbk.com;
nbme.howbk.com;
nbzj.howbk.com;
wzbze.howbk.com;
sxzje.howbk.com;
hzzj.howbk.com;
jhbjz.howbk.com;
jnbzm.howbk.com;
lyjz.howbk.com;
qdzjb.howbk.com;
whait.howbk.com;
dyzj.howbk.com;
ytjz.howbk.com;
wfjz.howbk.com;
heze.howbk.com;
int main(int argc, char* argv[])
{
std::string in;
cmatch what;
cout << "enter test string" << endl;
getline(cin,in);
if(regex_match(in.c_str(), what, expression))
{
for(int i=0;i<what.size();i++)
cout<<"str :"<<what.str()<<endl;
}
else
{
cout<<"Error Input"<<endl;
}
return 0;
}

  输入: select name from table

  输出: str:select name from table

  str:name

  str:table

  MFC下的测试(有几个地方要注意,下面有提示):

  新建一个对话框的MFC工程,

  加入头文件

  #include

  在按钮鼠标单击事件响应函数中加入

boost::regex expression("^select ([a-zA-Z]*) from ([a-zA-Z]*)");
CString in = "select gm from tab";
CString sRet;
boost::cmatch what;
if(boost::regex_match(LPCSTR(in), what, expression))//CString转string
{
 for(int i=0;i<what.size();i++){
  sRet = (what.str()).c_str();//string转CString
  MessageBox(sRet);
 }
}
else
{
MessageBox("Error Input");
}

  输出的结果跟上面一样。

资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 行列式是线性代数的核心概念,在求解线性方程组、分析矩阵特性以及几何计算中都极为关键。本教程将讲解如何用C++实现行列式的计算,重点在于如何输出分数形式的结果。 行列式定义如下:对于n阶方阵A=(a_ij),其行列式由主对角线元素的乘积,按行或列的奇偶性赋予正负号后求和得到,记作det(A)。例如,2×2矩阵的行列式为det(A)=a11×a22-a12×a21,而更高阶矩阵的行列式可通过Laplace展开或Sarrus规则递归计算。 在C++中实现行列式计算时,首先需定义矩阵类或结构体,用二维数组存储矩阵元素,并实现初始化、加法、乘法、转置等操作。为支持分数形式输出,需引入分数类,包含分子和分母两个整数,并提供与整数、浮点数的转换以及加、减、乘、除等运算。C++中可借助std::pair表示分数,或自定义结构体并重载运算符。 计算行列式的函数实现上,3×3及以下矩阵可直接按定义计算,更大矩阵可采用Laplace展开或高斯 - 约旦消元法。Laplace展开是沿某行或列展开,将矩阵分解为多个小矩阵的行列式乘积,再递归计算。在处理分数输出时,需注意避免无限循环和除零错误,如在分数运算前先约简,确保分子分母互质,且所有计算基于整数进行,最后再转为浮点数,以避免浮点数误差。 为提升代码可读性和可维护性,建议采用面向对象编程,将矩阵类和分数类封装,每个类有明确功能和接口,便于后续扩展如矩阵求逆、计算特征值等功能。 总结C++实现行列式计算的关键步骤:一是定义矩阵类和分数类;二是实现矩阵基本操作;三是设计行列式计算函数;四是用分数类处理精确计算;五是编写测试用例验证程序正确性。通过这些步骤,可构建一个高效准确的行列式计算程序,支持分数形式计算,为C++编程和线性代数应用奠定基础。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值