string 用法简单整理

一.string 头文件

string 类的成员函数有很多,同一个名字的函数也常会有五六个重载的版本,这里只整理常用的几个。

头文件:

#include <string> //注意这里不是string.h string.h是C字符串头文件

二.string初始化

(1).几个常用初始化

//string的初始化,在C++中字符串是一种数据类型;

string s1 = "abcdefghijk";

string s2("abcdefghijk");

string s3(s2);

string s4 = s1;  //调用拷贝构造函数;

string s5(10, 'a');//10个空间中的字符都是'a';

s5 = s1;
string s6 = s1 + s2;  //string可以直接加,和append加到末尾一样

(2). 赋值

string s1;
s1 = "12345";  // s1 = "12345"

//assign 成员函数,可以用来对 string 对象赋值,  没怎么用过
string s2;
s2.assign(s1);  // s2 = s1

三. string 常用函数

(1). substr操作,返回某个子字符串

 string s="abcdefg";
 //s.substr(pos1,n)返回字符串位置为pos1后面的n个字符组成的串
 string s2=s.substr(1,5);
 //bcdef
 //s.substr(pos)//得到一个pos到结尾的串

(2). size(),length() ,返回字符数量

for(int i = 0;  i < s1.size(); i++)  //length同
        cout << s1[i] << " ";

(3). find和rfind函数,通常搭配substr不错

find函数主要是查找一个字符串是否在调用的字符串中出现过,返回第一个出现的位置,大小写敏感。

rfind函数就是找最后一个出现的匹配字符串,返回的位置仍然是从前往后数的。

 std::string str ("There are two needles in this haystack with needles.");
 std::string str2 ("needle");
 
 //在str当中查找第一个出现的needle,找到则返回出现的位置下标,否则返回结尾
 std::size_t found = str.find(str2);
 //std::size_t found = str.find("needle");  //和上面相同

 //在str当中,从第found+1的位置开始查找参数字符串的前6个字符
 found=str.find("needles are small",found+1,6);
std::string str ("The sixth sick sheik's sixth sheep's sick.");
std::string key ("sixth");//     ^
//rfind是找最后一个出现的匹配字符串下标
std::size_t found = str.rfind(key);

(4). 交换两个string对象的内容
swap 成员函数可以交换两个 string 对象的内容。例如:

string s1("West”), s2("East");
s1.swap(s2);  // s1 = "East",s2 = "West"

四. string一些常用操作

(1). 遍历

//数组方式
for(int i = 0;  i < s1.length(); i++)
        cout << s1[i] << " ";
        
//迭代器方式
    for(string::iterator it = s1.begin(); it != s1.end(); it++)
        cout << *it << " ";

(2). 查找,替换

string s1 = "wbm hello wbm 111 wbm 222 wbm 333";

//1、第一次出现wbm的下标
int index = s1.find("wbm", 0); 

//2、求wbm每一次出现的数组下标
int offindex = s1.find("wbm", 0);
while(offindex != -1){
	offindex += strlen("wbm");
	offindex = s1.find("wbm", offindex);
    }

//替换的函数,替换后为AAA bbb ccc
string s3 = "aaa bbb ccc";
s3.replace(0, 3, "AAA");  

(3). 区间的删除和插入

string s1 = "hello1 hello2 hell03";
s1.erase(s1.begin(), s1.end()); //删除从pos开始的n个字符;


s2.insert(0, "AAA");  //头插法
s2.insert(s2.length(), "CCC");//尾插法

五. string一些转换

string转换
to_string(val)把val转换成string
s.c_str()string转化为char[]
<think>好的,我需要帮助用户找到在Spring Boot中实现数据导入导出的示例教程。用户提到了参考的引用内容,其中提到了依赖添加、自定义监听器、实体类定义和控制层实现等步骤。首先,我应该整理这些步骤,并确保每个部分都清晰明了。 首先,添加依赖是关键,用户需要引入Apache POI或Alibaba EasyExcel。根据引用[1]和[2],可能更推荐使用EasyExcel,因为它处理大文件更高效。接下来是实体类定义,这部分需要与Excel的列对应,使用注解来映射字段,比如@ExcelProperty。 然后,控制层的实现分导出和导入。导出数据时,设置响应头,使用EasyExcel的write方法。导入数据则涉及上传文件,并通过监听器处理数据,可能还需要自定义监听器来逐行读取,避免内存溢出,这在引用[1]中提到了自定义监听器作为可选步骤。 用户可能需要代码示例,所以需要写出具体的Controller方法,导出和导入的代码结构。同时,要提到优化点,比如异步处理或分页查询,引用[1]中的高效实现可能涉及这些方面。 另外,需要确保回答符合系统级指令,比如行内公式用$,但这个问题可能不涉及数学公式,所以可能不需要。但如果有任何公式,比如计算性能优化的部分,可能需要用LaTeX,不过目前看起来不需要。回答的结构要清晰,分步骤说明,并引用提供的参考资料,比如在依赖添加部分引用[1]和[2]。 最后,生成相关问题,考虑用户可能进一步询问如何优化导入性能,如何处理大数据量,或者如何整合到现有项目中等。根据引用内容,性能优化和大文件处理已经提到过,所以相关问题可以围绕这些点展开。 需要检查是否所有引用都正确标注,比如在提到依赖时引用[1],在导入导出的代码示例引用[2]和[3]。同时,确保代码块使用正确的语法,比如Java的代码标记,并正确缩进。 总结回答结构:先概述,然后分步骤讲解依赖、实体类、控制层实现,给出代码示例,最后优化建议和相关问题。确保每个部分都自然地引用对应的文献,比如在提到监听器时引用[1],在导入方法引用[2]中的URL路径,导出接口引用[3]中的部分。</think>在Spring Boot中实现数据导入导出功能,可通过Apache POI或Alibaba EasyExcel库高效处理Excel文件。以下是分步实现方法及示例: --- ### **1. 添加依赖** 使用EasyExcel(基于Apache POI优化,适合大数据量): ```xml <!-- pom.xml --> <dependency> <groupId>com.alibaba</groupId> <artifactId>easyexcel</artifactId> <version>3.1.1</version> </dependency> ``` > 引用[1]提到依赖管理是第一步[^1]。 --- ### **2. 定义实体类** 通过注解映射Excel列与实体字段: ```java public class User { @ExcelProperty("用户ID") private Long id; @ExcelProperty("用户名") private String name; @ExcelProperty("邮箱") private String email; // 省略getter/setter } ``` --- ### **3. 实现数据导出** 在Controller中生成Excel并写入响应流: ```java @GetMapping("/export") public void exportUsers(HttpServletResponse response) throws IOException { response.setContentType("application/vnd.ms-excel"); response.setHeader("Content-Disposition", "attachment; filename=users.xlsx"); List<User> userList = userService.getAllUsers(); EasyExcel.write(response.getOutputStream(), User.class).sheet("用户列表").doWrite(userList); } ``` > 引用[3]提到了接口导出Excel的响应设置[^3]。 --- ### **4. 实现数据导入** 通过监听器逐行读取上传的Excel文件: ```java @PostMapping("/import") public String importUsers(@RequestParam("file") MultipartFile file) { try { EasyExcel.read(file.getInputStream(), User.class, new UserDataListener(userService)) .sheet() .doRead(); return "导入成功"; } catch (IOException e) { return "导入失败:" + e.getMessage(); } } ``` > 引用[2]中的代码路径展示了POST请求处理文件上传[^2]。 --- ### **5. 自定义监听器(优化内存)** ```java public class UserDataListener extends AnalysisEventListener<User> { private final UserService userService; public UserDataListener(UserService userService) { this.userService = userService; } @Override public void invoke(User user, AnalysisContext context) { userService.save(user); // 逐行保存 } @Override public void doAfterAllAnalysed(AnalysisContext context) { // 数据读取完成后的操作 } } ``` > 引用[1]指出自定义监听器可优化大文件处理。 --- ### **优化建议** - **异步处理**:导入时使用`@Async`避免阻塞主线程。 - **分页查询**:导出大数据时分批读取数据库。 - **模板校验**:添加Excel表头校验逻辑。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值