青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴(yán)以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

兩個 CSV 解析類

其一:
/* Copyright (C) 1999 Lucent Technologies */
/* Excerpted from 'The Practice of Programming' */
/* by Brian W. Kernighan and Rob Pike */

#include 
<iostream>
#include 
<algorithm>
#include 
<string>
#include 
<vector>

using namespace std;

class Csv
{    // read and parse comma-separated values
    
// sample input: "LU",86.25,"11/4/1998","2:19PM",+4.0625

public:
    Csv(istream
& fin = cin, string sep = ",") : 
      fin(fin), fieldsep(sep) 
{}

      
int getline(string&);
      
string getfield(int n);
      
int getnfield() const return nfield; }

private:
    istream
& fin;            // input file pointer
    string line;            // input line
    vector<string> field;    // field strings
    int nfield;                // number of fields
    string fieldsep;        // separator characters

    
int split();
    
int endofline(char);
    
int advplain(const string& line, string& fld, int);
    
int advquoted(const string& line, string& fld, int);
}
;

// endofline: check for and consume \r, \n, \r\n, or EOF
int Csv::endofline(char c)
{
    
int eol;

    eol 
= (c=='\r' || c=='\n');
    
if (c == '\r')
    
{
        fin.
get(c);
        
if (!fin.eof() && c != '\n')
            fin.putback(c);    
// read too far
    }

    
return eol;
}


// getline: get one line, grow as needed
int Csv::getline(string& str)
{    
    
char c;

    
for (line = ""; fin.get(c) && !endofline(c); )
        line 
+= c;
    split();
    str 
= line;
    
return !fin.eof();
}


// split: split line into fields
int Csv::split()
{
    
string fld;
    
int i, j;

    nfield 
= 0;
    
if (line.length() == 0)
        
return 0;
    i 
= 0;

    
do {
        
if (i < line.length() && line[i] == '"')
            j 
= advquoted(line, fld, ++i);    // skip quote
        else
            j 
= advplain(line, fld, i);
        
if (nfield >= field.size())
            field.push_back(fld);
        
else
            field[nfield] 
= fld;
        nfield
++;
        i 
= j + 1;
    }
 while (j < line.length());

    
return nfield;
}


// advquoted: quoted field; return index of next separator
int Csv::advquoted(const string& s, string& fld, int i)
{
    
int j;

    fld 
= "";
    
for (j = i; j < s.length(); j++)
    
{
        
if (s[j] == '"' && s[++j] != '"')
        
{
            
int k = s.find_first_of(fieldsep, j);
            
if (k > s.length())    // no separator found
                k = s.length();
            
for (k -= j; k-- > 0; )
                fld 
+= s[j++];
            
break;
        }

        fld 
+= s[j];
    }

    
return j;
}


// advplain: unquoted field; return index of next separator
int Csv::advplain(const string& s, string& fld, int i)
{
    
int j;

    j 
= s.find_first_of(fieldsep, i); // look for separator
    if (j > s.length())               // none found
        j = s.length();
    fld 
= string(s, i, j-i);
    
return j;
}



// getfield: return n-th field
string Csv::getfield(int n)
{
    
if (n < 0 || n >= nfield)
        
return "";
    
else
        
return field[n];
}


// Csvtest main: test Csv class
int main(void)
{
    
string line;
    Csv csv;

    
while (csv.getline(line) != 0)
    
{
        cout 
<< "line = `" << line <<"'\n";
        
for (int i = 0; i < csv.getnfield(); i++)
            cout 
<< "field[" << i << "] = `"
            
<< csv.getfield(i) << "'\n";
    }

    
return 0;
}




其二:
來源于:http://www.mayukhbose.com/freebies/c-code.php
頭文件:
#ifndef __CSVPARSE_H_2001_06_07__
#define __CSVPARSE_H_2001_06_07__

/*
Copyright (c) 2001, Mayukh Bose
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are
met:

* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.  

* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.

* Neither the name of Mayukh Bose nor the names of other
contributors may be used to endorse or promote products derived from
this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/


#include 
<string>
using namespace std;

class CSVParser {
 
private:
  
string m_sData;
  
string::size_type m_nPos;
  
void SkipSpaces(void);
 
public:
  CSVParser();
  
const CSVParser & operator << (const string &sIn);
  
const CSVParser & operator << (const char *sIn);
  CSVParser 
& operator >> (int &nOut);
  CSVParser 
& operator >> (double &nOut);
  CSVParser 
& operator >> (string &sOut);
}
;

#endif

cpp
/*
Copyright (c) 2001, Mayukh Bose
All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are
met:

* Redistributions of source code must retain the above copyright notice,
this list of conditions and the following disclaimer.  

* Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.

* Neither the name of Mayukh Bose nor the names of other
contributors may be used to endorse or promote products derived from
this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/


#include 
<iostream>
#include 
<cstdlib>
#include 
"csvparser.h"
using namespace std;


CSVParser::CSVParser()
{
  m_sData 
= "";
  m_nPos 
= 0;
}


void CSVParser::SkipSpaces(void)
{
  
while (m_nPos < m_sData.length() && m_sData[m_nPos] == ' ')
    m_nPos
++;
}


const CSVParser & CSVParser::operator <<(const string & sIn)
{
  
this->m_sData = sIn;
  
this->m_nPos = 0;
  
return *this;
}


const CSVParser & CSVParser::operator <<(const char *sIn)
{
  
this->m_sData = sIn;
  
this->m_nPos = 0;
  
return *this;
}


CSVParser 
& CSVParser::operator >>(int & nOut)
{
  
string sTmp = "";
  SkipSpaces();
  
while (m_nPos < m_sData.length() && m_sData[m_nPos] != ',')
    sTmp 
+= m_sData[m_nPos++];

  m_nPos
++// skip past comma
  nOut = atoi(sTmp.c_str());
  
return *this;
}


CSVParser 
& CSVParser::operator >>(double & nOut)
{
  
string sTmp = "";
  SkipSpaces();
  
while (m_nPos < m_sData.length() && m_sData[m_nPos] != ',')
    sTmp 
+= m_sData[m_nPos++];

  m_nPos
++// skip past comma
  nOut = atof(sTmp.c_str());
  
return *this;
}


CSVParser 
& CSVParser::operator >>(string & sOut)
{
  
bool bQuotes = false;
  sOut 
= "";
  SkipSpaces();

  
// Jump past first " if necessary
  if (m_nPos < m_sData.length() && m_sData[m_nPos] == '"'{
    bQuotes 
= true;
    m_nPos
++
  }

  
  
while (m_nPos < m_sData.length()) {
    
if (!bQuotes && m_sData[m_nPos] == ',')
      
break;
    
if (bQuotes && m_sData[m_nPos] == '"'{
      
if (m_nPos + 1 >= m_sData.length() - 1)
        
break;
      
if (m_sData[m_nPos+1== ',')
        
break;
    }

    sOut 
+= m_sData[m_nPos++];
  }


  
// Jump past last " if necessary
  if (bQuotes && m_nPos < m_sData.length() && m_sData[m_nPos] == '"')
    m_nPos
++

  
// Jump past , if necessary
  if (m_nPos < m_sData.length() && m_sData[m_nPos] == ',')
    m_nPos
++

  
return *this;
}



posted on 2008-06-03 11:26 楊粼波 閱讀(2332) 評論(1)  編輯 收藏 引用

評論

# re: 兩個 CSV 解析類 2008-10-16 09:49 傲天

這片文章不錯,我喜歡,謝謝博主  回復(fù)  更多評論   


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            9国产精品视频| 久久中文字幕一区| 亚洲二区视频在线| 夜夜嗨av一区二区三区| 先锋影音网一区二区| 男人的天堂亚洲在线| 亚洲精品在线免费| 久热精品视频在线观看一区| 亚洲国产影院| 亚洲主播在线观看| 免费不卡视频| 国产精品一区二区a| 亚洲国产裸拍裸体视频在线观看乱了| 在线一区欧美| 免费视频最近日韩| 亚洲一区www| 免费欧美日韩| 国产精品永久入口久久久| 亚洲国产精品一区二区久| 午夜精品成人在线视频| 欧美国产欧美综合 | 亚洲理论电影网| 欧美一区视频| 欧美日韩国产影片| 在线观看视频欧美| 性娇小13――14欧美| 亚洲激情网站| 久久久久综合一区二区三区| 国产精品久久午夜| 亚洲另类一区二区| 免费成人av在线看| 先锋影院在线亚洲| 亚洲一区三区视频在线观看| 欧美激情精品久久久久久大尺度| 国产日本欧美一区二区| 亚洲午夜av在线| 亚洲国产精品精华液2区45| 欧美在线影院| 国产精品一区久久久| 一区二区三区视频在线| 欧美成人自拍| 久久久久久综合| 久久国产精品免费一区| 国产精品久久久亚洲一区| 日韩亚洲一区在线播放| 模特精品在线| 久久国产精品高清| 国产精品久久久久毛片软件| 亚洲少妇中出一区| 亚洲精品五月天| 欧美成人免费在线| 亚洲国产精品综合| 欧美v日韩v国产v| 久久九九有精品国产23| 久久丁香综合五月国产三级网站| 国产乱码精品一区二区三区不卡 | 午夜综合激情| 亚洲一级黄色| 国产精品美女xx| 午夜精品福利电影| 中文亚洲视频在线| 亚洲影视在线播放| 国产精品网站在线播放| 亚洲欧美日韩在线| 亚洲综合视频一区| 国产日韩欧美精品在线| 久久精品成人一区二区三区蜜臀| 亚洲欧美日本国产有色| 国产精品亚洲一区二区三区在线| 欧美一区日韩一区| 翔田千里一区二区| 韩国久久久久| 亚洲人成网站777色婷婷| 欧美国产乱视频| 欧美fxxxxxx另类| 亚洲美女精品成人在线视频| 亚洲人成绝费网站色www| 欧美巨乳在线观看| 亚洲一区不卡| 午夜亚洲性色福利视频| 国产一区导航| 久久综合一区| 欧美77777| 夜夜嗨网站十八久久 | 欧美一区激情| 激情综合在线| 亚洲高清三级视频| 欧美日韩系列| 欧美中文在线观看| 久久久国产精品亚洲一区| 尹人成人综合网| 91久久久亚洲精品| 欧美日韩在线视频一区二区| 亚洲一区二区三区四区在线观看| 亚洲欧美视频在线| 1000部精品久久久久久久久| 亚洲国产精品一区二区第四页av| 欧美日韩 国产精品| 香蕉免费一区二区三区在线观看| 欧美中文字幕在线视频| 亚洲欧洲久久| 亚洲一区精品在线| 在线欧美视频| 日韩视频免费看| 国产尤物精品| 最近中文字幕日韩精品| 国产精品私拍pans大尺度在线| 久久婷婷国产综合精品青草| 欧美激情一区二区三区蜜桃视频| 亚洲婷婷综合久久一本伊一区| 亚洲高清在线视频| 国产精品电影观看| 久久综合久久久久88| 欧美国产一区二区| 午夜精品在线观看| 美女精品在线| 亚洲欧美精品一区| 老妇喷水一区二区三区| 亚洲在线成人精品| 久久躁狠狠躁夜夜爽| 亚洲视频中文| 久久久久综合一区二区三区| 亚洲社区在线观看| 久久久久久久激情视频| 亚洲图片你懂的| 久久婷婷av| 亚洲一区在线观看视频| 久久综合网络一区二区| 欧美一区二区福利在线| 欧美成人精品影院| 久久久久久91香蕉国产| 欧美日韩午夜| 欧美电影资源| 国产日韩欧美在线视频观看| 最新高清无码专区| 伊人春色精品| 午夜一区在线| 亚洲午夜精品在线| 亚洲麻豆视频| 亚洲国产激情| 欧美专区第一页| 午夜精品免费在线| 欧美人成免费网站| 欧美成人蜜桃| 久久久亚洲综合| 久久狠狠婷婷| 国产精品久久久久久久久久ktv| 欧美成人免费播放| 极品av少妇一区二区| 亚洲欧美日韩第一区| 亚洲图片欧美午夜| 欧美久久久久久久久久| 欧美成人激情视频| 韩日精品在线| 亚洲欧美视频在线| 亚洲欧美在线播放| 欧美性大战久久久久久久| 亚洲第一区色| 欧美激情精品久久久| 欧美sm视频| 亚洲第一级黄色片| 久久久xxx| 久久亚洲二区| 国产亚洲欧美一级| 欧美在线观看视频一区二区三区 | 性色av香蕉一区二区| 欧美视频日韩视频| 亚洲精品老司机| 欧美视频精品一区| 日韩图片一区| 一区二区三区四区精品| 欧美精品三级| 亚洲日本中文字幕| 亚洲免费成人av电影| 欧美国产日韩一区二区在线观看| 男同欧美伦乱| 亚洲国产精品一区二区第一页| 久久美女性网| 欧美va亚洲va香蕉在线| 亚洲经典一区| 欧美—级a级欧美特级ar全黄| 欧美黄色一区| 日韩一区二区精品| 欧美日韩视频不卡| 在线亚洲欧美| 午夜精品一区二区三区在线视| 国产精品一区免费视频| 亚洲欧美在线磁力| 久久露脸国产精品| 亚洲大胆美女视频| 欧美jizz19hd性欧美| 亚洲日本免费电影| 一区二区三区不卡视频在线观看| 欧美日韩喷水| 亚洲免费网站| 久久影视三级福利片| 亚洲国产第一页| 欧美连裤袜在线视频| 这里只有视频精品| 久久国产精品亚洲77777|