C++從文件中提取英文單詞的實(shí)現(xiàn)方法
首先,要準(zhǔn)備好words.txt(英文文章)置于工程目錄下
思路:
1.打開文件
2.讀取每一行
3.找到特殊的標(biāo)點(diǎn)符號(hào)的位置,進(jìn)行刪除。
4.根據(jù)空格截取單詞 find(" ");
5.將拿到的每一個(gè)單詞放在鏈表中
一:讀取一行,去除該行標(biāo)點(diǎn)符號(hào)
#include<iostream>
using namespace std;
#include<fstream>
#include<string>
#include<list>
void test_word_split();
int main()
{
test_word_split();
return 0;
}
void test_word_split()
{
fstream fs;
char filename[20] = {0};
cout<<"請(qǐng)輸入打開的文件名:";
cin>>filename;
//打開文件
fs.open(filename);
cout<<"打開成功"<<filename<<endl;
char buf[1024] = {0};
fs.getline(buf,1024);//讀取每一行
cout<<buf<<endl;
size_t pos; //找到位置
string line; //接替buf職責(zé)
line = buf;
pos = line.find_first_of(",.;:'?!()/\""); //找特殊的標(biāo)點(diǎn)符號(hào)
while(pos!=string::npos)
{ //刪除單個(gè)字符
line.erase(pos,1);
//再找下一個(gè)單個(gè)的字符
pos = line.find_first_of(",.;:'?!()/\"");
}
cout<<line.c_str()<<endl; //string 轉(zhuǎn)char
}

二:截取單詞
#include<iostream>
using namespace std;
#include<fstream>
#include<string>
#include<list>
void test_word_split();
int main()
{
test_word_split();
return 0;
}
void test_word_split()
{
fstream fs;
char filename[20] = {0};
cout<<"請(qǐng)輸入打開的文件名:";
cin>>filename;
//打開文件
fs.open(filename);
cout<<"打開成功"<<filename<<endl;
char buf[1024] = {0};
fs.getline(buf,1024);//讀取每一行
cout<<buf<<endl;
size_t pos;
string line,word;
line = buf;
pos = line.find_first_of(",.;:'?!()/\""); //找特殊的標(biāo)點(diǎn)符號(hào)
while(pos!=string::npos)
{ //刪除單個(gè)字符
line.erase(pos,1); //從什么位置開始刪除多長(zhǎng)的字符
//再找下一個(gè)單個(gè)的字符
pos = line.find_first_of(",.;:'?!()/\"");
}
cout<<line.c_str()<<endl; //string 轉(zhuǎn)char
//根據(jù)空格截取單詞 find("") 111 222 333
pos = line.find(" ");
while(pos!=string::npos)
{
//截取單詞
word = line.substr(0,pos);//從0開始,一直截到空格所在位置
cout<<word<<endl;
//把第一個(gè)單詞以及空格刪除
line.erase(0,pos+1); //從什么位置開始刪除多長(zhǎng)的字符(如刪111 )因此pos+1
pos = line.find(" "); //尋找下一個(gè)空格
}
}

三:將拿到的每一個(gè)單詞都放在鏈表中
#include<iostream>
using namespace std;
#include<fstream>
#include<string>
#include<list>
void test_word_split();
int main()
{
test_word_split();
return 0;
}
void test_word_split()
{
list<string> wordList;//鏈表
fstream fs;
char filename[20] = {0};
cout<<"請(qǐng)輸入打開的文件名:";
cin>>filename;
fs.open(filename);
cout<<"打開成功"<<filename<<endl;
char buf[1024] = {0};
string line,word; //初始化定義
while(fs.getline(buf, 1024))//讀取每一行
{
size_t pos; //找到位置
line = buf; //接替buf職責(zé)
pos = line.find_first_of(",.;:'?!()/\"");
while(pos!=string::npos)//!=npos就找到
{
line.erase(pos,1); //從什么位置開始刪除多長(zhǎng)字符
pos = line.find_first_of(",.;:'?!()/\"");//尋找下一個(gè)標(biāo)點(diǎn)符號(hào)
}
pos = line.find(" "); //尋找空格所在位置
while(pos!=string::npos)
{
word = line.substr(0,pos);//從0開始,一直截到空格所在位置
wordList.push_back(word); //拿到的單詞放在鏈表中
//把第一個(gè)單詞以及空格刪除
line.erase(0, pos+1);//從什么位置開始刪除多長(zhǎng)的字符(如刪111 )因此pos+1
pos = line.find(" ");//尋找下一個(gè)空格
}
}
cout<<"驗(yàn)證一下"<<endl;
list<string>::iterator it;
for(it = wordList.begin();it!=wordList.end();it++)
{
cout<<(*it).c_str()<<endl;
}
cout<<"總的個(gè)數(shù):"<<wordList.size();
fs.close();
}最后的結(jié)果:

到此這篇關(guān)于C++從文件中提取英文單詞的實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)C++ 文件中提取英文單詞內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++詳細(xì)分析lambda表達(dá)式的本質(zhì)
Lambda表達(dá)式是現(xiàn)代C++在C ++ 11和更高版本中的一個(gè)新的語法糖 ,在C++11、C++14、C++17和C++20中Lambda表達(dá)的內(nèi)容還在不斷更新。 lambda表達(dá)式(也稱為lambda函數(shù))是在調(diào)用或作為函數(shù)參數(shù)傳遞的位置處定義匿名函數(shù)對(duì)象的便捷方法2022-06-06
深入分析C++中兩個(gè)大數(shù)相乘結(jié)果不正確的問題
本篇文章是對(duì)C++中兩個(gè)大數(shù)相乘結(jié)果不正確的問題進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
C語言實(shí)現(xiàn)餐飲點(diǎn)餐管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)餐飲點(diǎn)餐管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01
C++ opencv圖像處理實(shí)現(xiàn)圖片幾何變換示例
這篇文章主要為大家介紹了C++ opencv圖像處理實(shí)現(xiàn)圖片幾何變換示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05

