C++ 将string字符串按照特殊的多个字符分割

遇到一个任务,将用户的时间对比,然后给出差值。其中需要将string格式的时间组装成一个time_t类型。用户的输入格式是“2014-11-10 9:09:32.111”。为了组装,我必须将他们全部分割。其中发现大部分人都是按照某一个特定的字符分割的,而其还比较复杂,我想这样做效率肯定低下。因此,自己写了一个,供大家参考:

#include<iostream>
#include<string.h>
#include<vector>
using namespace std;
vector<string> split(string strTime)
{
    vector<string> result;
    string temp("");
    strTime+='-';//字符串结束标记,方便将最后一个单词入vector
    for(size_t i = 0; i < strTime.size(); i++)
    {
        if(strTime[i] == '-' || strTime[i] == '.' || strTime[i] == ' ' ||strTime[i] == ':')
        {
            result.push_back(temp);
            temp = "";
        }
        else
        {
            temp += strTime[i];
        }
    }
    return result;
}

int main()
{
    string strtime="2014-11-10 14:55:40.123";
    vector<string> result = split(strtime);
    for(size_t i = 0; i < result.size(); i++)
    {
        cout<<result[i]<<"  ";
    }
    return 0;
}

想上面这样,就可以将一个string按照一组字符分割了。分割后可以组装到其他结构中,比如struct tm中的年月日等就是用上述分割后的字段填充的。


<> 一些背景知识: 1. 一个汉字在c\c++的存储, 使用2个字节(char)存储; 2. 汉字存储的第一个char, 其值一定大于'~'(0111 1110=126),否则将导致识别歧义; 此处, 使用"单ASCII字符"来表示非 单ASCII字符的判断, 可以根据以下规则(主要R3, R4); : 一个字符串的长度==1,那肯定是一个ASCII字符; : 一个字符串的长度==2,且第1个ASCII字符的编码小于'~'; 那肯定是2个单ASCII字符; -- (PS: "") : 一个字符串的长度==3,且中间的ASCII字符的编码小于'~'; 那第3个肯定是单ASCII字符; (前2个是否构成1个汉字不能确定) : (基于R3)如果第pos个位置的ASCII字符编码小于'~', 那从下标pos,pos+1处拆分字符串 (下标pos归前串),将不会导致乱码; A 或者 B 的选择,需要知道以下信息: (1). 从 cut_base_pos 开始到 pos_B 结束的这段字符串内, 最后一个单ASCII字符的结束下标 p 在此基础上, 若使用: y -- 表示单ASCII字符(已确定的); x -- 表示可能是 单ASCII字符,也可能是 汉字的半个ASCII存储码; 那么一段长度为N的字符串,按照存储的ASCII码可以表示为一串如下的字符串(不包含[]) "x .. x][x .. x y x .. x][x .. x", 其中 s,e表示当前正在分析的一段子串(0<=s<e<=N, 下标e-s = 期望的分割长度cut_size) ^ ^ ^ ^ ^ 0 s p e N 在 【s, e】 之间, 查找结束下标p 的思路: 从e开始向s查找, 找到 第一个y 后 break; 记录下标p, 则从位置p开始, 是一个正确的分割(cut); 但此分割并不是一个最好的分割. 可以在 位置p上, 再加上 2K 个长度, 使 p+2K 与 pos_B 最接近即可. 可以认为从2K个长度的内容是K个汉字(实际上并不一定..), 但并不影响这个最佳分割的正确性! :)
在C语言中,可以使用两种方法对string字符串进行分割。第一种方法是使用find()函数配合substr()函数,第二种方法是使用strtok()函数。 使用find()函数和substr()函数的方法如下: 1. 使用find()函数找到分割符在字符串中的位置。 2. 使用substr()函数从字符串中截取需要的部分。 3. 重复以上步骤直到将整个字符串分割完毕。 使用strtok()函数的方法如下: 1. 使用strtok()函数设置分割符。 2. 使用strtok()函数依次获取分割后的子字符串。 3. 重复以上步骤直到将整个字符串分割完毕。 需要注意的是,在C语言中,String类没有直接提供字符串分割函数,需要自己编写代码实现。 可以参考网上给出的解决方案来实现字符串分割。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C++ string字符串分割](https://blog.youkuaiyun.com/qq_35308053/article/details/113643398)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [详解C++String类的字符串分割实现](https://download.youkuaiyun.com/download/weixin_38745891/14874671)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值