find_first_of()和 find_last_of()
string 类提供字符串处理函数,利用这些函数,程序员可以在字符串内查找字符,
提取连续字符序列(称为子串),以及在字符串中删除和添加。我们将介绍一些主要函数。
1.函数find_first_of()和 find_last_of() 执行简单的模式匹配
例如:在字符串中查找单个字符c。
函数find_first_of() 查找在字符串中第1个出现的字符c,而函数find_last_of()查找最后
一个出现的c。匹配的位置是返回值。如果没有匹配发生,则函数返回-1.
int find_first_of(char c, int start = 0):
查找字符串中第1个出现的c,由位置start开始。
如果有匹配,则返回匹配位置;否则,返回-1.默认情况下,start为0,函数搜索
整个字符串。
int find_last_of(char c):
查找字符串中最后一个出现的c。有匹配,则返回匹配位置;否则返回-1.
该搜索在字符末尾查找匹配,所以没有提供起始位置。
示例:
- <span style="font-family:Courier New;font-size:16px;"> string str = "Mississippi";
- int index;
- // 's ' 在index 为 2、3、5、6处出现
- index = str.find_first_of('s',0); // index为 2
- index = str.find_first_of('s',4); // index为 5
- index = str.find_first_of('s',7); // index为 -1
- // ‘s’的最后出现在 index= 6
- index = str.find_last_of('s');
- // while 循环输出每个'i'的index
- while((index = str.find_first_of('i', index))!= -1)
- {
- cout << "index" << index << " ";
- index++; // restart search at next indx
- }</span>
输出结果: index 1 index 4 index 7 index 10
2.字符串中提取连续字符序列,既子串。
这个操作假定位置 start 和 字符数 count.
string substr(int start=0,int count= -1);
从起始位置开始复制字符串中的count 个字符,并返回这些字符作为子串。
如果字符串尾部小于count字符或者count 为-1,则字符串尾停止复制。
如果不使用参数调用只包括位置start,则substr()返回从位置开始到字符串尾部的子串。
find()函数在字符串中查找指定模式。该函数将字符串s和位置start作为参数,并查找
s的匹配作为子串。
int find(const string& s,int start = 0):
该搜索获得字符串s和位置start,并查找s的匹配作为子串。
如果有匹配,则返回匹配的位置;否则返回-1。默认情况下,
start为0,函数搜索整个字符串。
示例
- <span style="font-family:Courier New;font-size:16px;"> string fullname = "Mark Tompkin", firstname, lastname;
- int index;
- index = str.find_last_of(' '); // index is 4
- // firstname = "Mark" lastname = "Tompkin"
- firstname = fullname.sub string(0,index);
- lastname = fullname.substring(index+1);
- index = fullname.find("kin"); // 在 index = 9 匹配 "Kin"
- index = fullname.find("omp",0); // 在 index = 6 匹配 "omp"
- index = fullname.find("omp",7); // index is -1 (无匹配)</span>
3.添加和删除字符串
字符连接(+、+=)是在字符串尾添加字符串。insert()函数扩展了这个能力,
允许在任意位置添加字符串。为了从字符串。为了从字符串中删除字符串,
函数erase()可以从指定的位置开始删除字符。
void insert(int statr,const string& s):
将子串s放入字符串中,起始于位置start。插入操作增加了原始字符串的长度。
void erase(int start=0,int count=-1):
从start开始,从字符串中删除count个字符。如果现有的字符串少于count个
字符,或者count为-1,则删除到字符串尾部的所有字符。默认情况下,start为0,函数
从字符串是起始位置开始删除字符串。默认情况下,函数也删除到字符串尾。
需要注意的是,不使用参数调用erase()函数时,将把字符串截断为长度为0的空字符串。
示例:
- <span style="font-family:Courier New;font-size:16px;"> string str = "endfile";
- string s = "string object type";
- str += " mark";
- str.inset(3, "-of-"); // str 是 "end-of-file mark"
- s.erase(7,7); // s 是 "string type"
- // 从index 为3处删除4个字符
- s.erase(3,4);
- cout << s; // 输出:"strtype"</span>
4.c_str()返回c语言风格字符串的地址。
将字符串对象转换为c语言风格字符串。
char *c_str();
返回一个等价于字符串对象的c语言风格字符串的地址。返回类型char*表示c
语言风格字符串第1个字符的地址。
示例:
- <span style="font-family:Courier New;font-size:16px;">string filename = "input.dat";
- // open 要求文件名是c语言风格的字符串
- fin.open(filename.c_str());</span>
5.分离字符串路径的方法
处理文件的程序可能要分析文件名。这种算法要进行字符串处理。文件可以
由路径名指定,路径名包括由分隔符"/"分割的名称集。最后一个"/"前的名称序列
称为路径。最后一个名称是文件名,还可能包括扩展名。
路径名 /class/programs/testfile.cpp
路径 /class/programs/
文件名 testfile.cpp
扩展名 cpp
为了分析文件名,我们从键盘读入完整的路径名,并输出路径和文件名。
如果文件名具有扩展名"cpp",则在创建可执行文件名时,将用"exe"替代扩展名"cpp".
下面是程序结构的轮廓,以及如何使用字符串函数的说明:
1.输入文件名,使用函数find_last_of()在字符串中搜索最后一个出现的"/"。这个字符
确定了路径的结尾和文件名的开始。
2。路径是由最后一个"/"前所有字符串组成的子串。文件名是最后一个"/"后的
所有字符。使用最后一个"/"的位置和substr()提取出路径和文件名。
3.扩展名是文件名中最好一个"."后的字符串。调用find_last_of()搜索最后一个匹配,
则复制文件名,删除当前扩展名,并添加新的扩展名"exe"。 输出产生的可执行文件名。
// 文件prg1_3.cpp
// 此程序提示用户输入文件的路径
// 它使用string类操作来识别并输出
// 路径名和文件名。如果文件名有
// 扩展名"cpp",则创建并输出
// 可执行文件的名称,其扩展名为"exe",替换
// 扩展名"cpp"
- <span style="font-family:Courier New;">// WJ.cpp : 定义控制台应用程序的入口点。
- //
- #i nclude "stdafx.h"
- #i nclude<iostream>
- #i nclude<string>
- using namespace std;
- int main()
- {
- string pathname, path, filename,executableFile;
- // ‘/’和 '.'的位置
- int backslashIndex, dotIndex;
- cout << "Enter the path name: ";
- cin >> pathname;
- // 识别最后一个'/'的位置。注意:由于
- // 转义码如'/n'以/起始,
- // c++ 使用'//'表示 /
- backslashIndex = pathname.find_last_of('//');
- //路径名是最后一个'/'之前的字符
- path = pathname.substr(0,backslashIndex);
- cout << "path: " << path << endl;
- // 路径名尾部是文件名
- filename = pathname.substr(backslashIndex+1,-1);
- cout << "Filename: " << filename << endl;
- // 查看文件名是否有'.cpp'扩展名。
- // 首先找到最后一个'.'的位置。 如果
- // 没有'.',则dotIndex为-1
- dotIndex = filename.find_last_of('.');
- //测试是否有'.',其余的字符是否为"cpp"
- if (dotIndex != -1 && filename.substr(dotIndex+1) == "cpp")
- {
- // 删除"cpp",并加上"exe"设置可执行字符串
- executableFile = filename;
- executableFile.erase(dotIndex+1,3);
- executableFile+="exe";
- cout << "Executable: " << executableFile << endl;
- }
- return 0;
- } </span>
输出结果:
第1次允许结果:
Enter the path name: /class/programs/testfile
path: /class/programs
Filename: testfile
第2次允许结果:
Enter the path name: programs/strings/filedemp.cpp
path: programs/strings
Filename: filedemo.cpp
Executable: filedemo.exe
第3次允许结果:
Enter the path name: /program.cpp
path:
Filename: program.cpp
Executable: program.exe
find_first_of()和 find_last_of()相关推荐
- find_first_of()和 find_last_of() 【获取路径、文件名】
string 类提供字符串处理函数,利用这些函数,程序员可以在字符串内查找字符,提取连续字符序列(称为子串),以及在字符串中删除和添加.我们将介绍一些主要函数. 1.函数find_first_of() ...
- std::string中的find_first_of()和find_last_of()函数
编程语言: c++/linux 在std::string中,有时需要找到一个string中最后一个或者第一个以某个特定的字符开始的位置或者下标,这时就需要使用find_first_of()和find_ ...
- string 基本用法
膜拜大佬orz http://www.cnblogs.com/OIerShawnZhou/ 最基本的,头文件 #include <cstring> #include <string ...
- 用法 stl_PoEdu培训第四课-C++之STL
C++是由C.object.STL以及泛型等四大块组成的C++语言联盟.下面我们就简单的了解以下STL中的string类. 我们使用的所有库函数都是编译器帮我们实现的,编译器根据C/C++或者其它语言 ...
- string :操作总结
创:assign,getline, 增:append,insert,push_back 查:at ,begin,capacity,data,empty,end,find find_first_not_ ...
- C++中有string类,string是一个类不是一种类型,c语言中没有
前言: string 的角色 1 string 使用 1.1 充分使用string 操作符 1.2 眼花缭乱的string find 函数 1.3 string insert, replace, er ...
- C++ Strings(字符串)
C++ Strings 构造函数(Constructors) 操作符(Operators) 添加文本(append) 赋值(assign) at begin c_str 容量(capacity) 比较 ...
- STL中map和string, vector 用法详解
1. map 用法详解 std map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力,由于这个特性,它完成 ...
- C++ string 用法详解(转)
C++ string 详解 任何人对本文进行引用都要标明作者是Nicolai M.Josuttis /// C++ 语言是个十分优秀的语言,但优秀并不表示完美.还是有许多人不愿意使用C或者C++,为什 ...
最新文章
- HDU 4418 高斯消元法求概率DP
- vue 生产word_nodejs(officegen)+vue(axios)在客户端导出word文档
- windbg 符号表
- 某合资源网4.5主题 完美无错版 emlog模板
- cad怎么选择一个对象打散vba_CAD制图的二十四字秘诀!
- java import lang_要使用lang包中的类,必须用import语句将java.lang程序包引入到源程序。...
- 阿里云播放器进度条拖拽
- 【基本办公软件】万彩办公大师教程丨彩色转化PDF为黑白PDF
- 维纶触摸屏程序实际项目,威纶通界面UI
- 高级运维需要掌握哪些技术?
- 蛋白质结构预测大赛top1方案分享
- Windows 远程桌面连接命令
- Shell脚本-Dong
- 柱状图、直方图、散点图、饼图讲解
- Foo,getName题解分析
- java 小程序 自己学习
- Chrome浏览器绿色、免安装版下载,长期更新
- 信捷DS5B伺服驱动器Modbus控制程序编写
- 工具条研究手记(2) - 认识CToolBar工具条类
- Vue下面安装Element 的详细步骤
热门文章
- python动力学建模与仿真_PyMC3中的简单动力学模型
- python设置一个初始为0的计数器_如何为python列表的每个元素实现一个计数器?...
- 超级大水题(还是自己过不了的水题)
- 方法 手写promise_手写Promise类
- php和ajax实现聊天功能,怎么在PHP项目中使用jquery与ajax实现一个即时聊天功能
- 随着电子计算机的应用 会计信息保存的形式,会计信息功系统简答题.doc
- mysql的本地id可以随便设置马_Mysql 都会遭受哪些方面的攻击?
- MySQL----获取当前日期当月第一天,最后一天
- plsql 自动查询最后页_一次SQL查询优化思考过程(900W+数据,从17s到300ms)
- IDEA debug模式,修改集合的值