您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)文本處理用c與用python哪個(gè)比較好,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
文本處理python與c的對(duì)比:如下
c++語(yǔ)言:
C++語(yǔ)言實(shí)現(xiàn)C++中沒(méi)有實(shí)現(xiàn)split功能的函數(shù),下面用C++ STL中的一些函數(shù)模擬實(shí)現(xiàn)split功能。#include <iostream>#include <string>#include <vector>#include <fstream>using namespace std;/* @in, src: 待分割的字符串 @in, delim: 分隔符字符串 @in_out, dest: 保存分割后的每個(gè)字符串 */void split(const string& src, const string& delim, vector<string>& dest){ string str = src; string::size_type start = 0, index; string substr; index = str.find_first_of(delim, start);//在str中查找(起始:start) delim的任意字符的第一次出現(xiàn)的位置 while(index != string::npos) { substr = str.substr(start, index-start); dest.push_back(substr); start = str.find_first_not_of(delim, index);//在str中查找(起始:index) 第一個(gè)不屬于delim的字符出現(xiàn)的位置 if(start == string::npos) return; index = str.find_first_of(delim, start); }}int main(){ ifstream infile("test.txt", ios::in); vector<string> results; string word; string delim(" "); string textline; if(infile.good()) { while(!infile.fail()) { getline(infile, textline); split(textline, delim, results); } } infile.close(); vector<string>::iterator iter = results.begin(); while(iter != results.end()) { cout<<*iter++<<endl; } return 0;}
python語(yǔ)言:
在Python中有專門的函數(shù)split()對(duì)字符串進(jìn)行分割,實(shí)現(xiàn)較為簡(jiǎn)單myfile = open('test.txt', 'r')allWords = []line = myfile.readline()while line: list = line.split(' ') for word in list: if word[-1]=='\n': allWords.append(word[:-1])#去掉行末的'\n' else: allWords.append(word) line = myfile.readline()myfile.close()print allWords
相比較而言,(拋開(kāi)運(yùn)行效率不說(shuō)),開(kāi)發(fā)效率比較好的是Python,然后是c++,(但是一旦c++這些方法提前包裝好了,也是很不錯(cuò)的)。
關(guān)于文本處理用c與用python哪個(gè)比較好就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。