在 c + + 中使用 ifstream 逐行读取文件

The contents of file.txt are:

5 3
6 4
7 1
10 5
11 6
12 3
12 4

Where 5 3 is a coordinate pair. How do I process this data line by line in C++?

I am able to get the first line, but how do I get the next line of the file?

ifstream myfile;
myfile.open ("text.txt");

转载于:https://stackoverflow.com/questions/7868936/read-file-line-by-line-using-ifstream-in-c

7个回答

First, make an ifstream:

#include <fstream>
std::ifstream infile("thefile.txt");

The two standard methods are:

  1. Assume that every line consists of two numbers and read token by token:

    int a, b;
    while (infile >> a >> b)
    {
        // process pair (a,b)
    }
    
  2. Line-based parsing, using string streams:

    #include <sstream>
    #include <string>
    
    std::string line;
    while (std::getline(infile, line))
    {
        std::istringstream iss(line);
        int a, b;
        if (!(iss >> a >> b)) { break; } // error
    
        // process pair (a,b)
    }
    

You shouldn't mix (1) and (2), since the token-based parsing doesn't gobble up newlines, so you may end up with spurious empty lines if you use getline() after token-based extraction got you to the end of a line already.

weixin_41568174
from.. No, the boolean conversion checks for !fail(), not good(), which differs in the treatment of EOF (see here).
2 年多之前 回复
csdnceshi80
胖鸭 Thanks got the EOF part, just figured out that directly using ifstream for a condition check will trigger the bool operator that will return false if eof is hit, and cause the loop to break.
2 年多之前 回复
weixin_41568174
from.. If you're reading in a way that doesn't "read ahead", like just getting individual characters out, then you never trigger EOF until you actually step over the end of the stream: wandbox.org/permlink/oFaYFTFtnEfucaMv
2 年多之前 回复
weixin_41568174
from.. the stream reaches EOF while reading digits to form the last element. It is in the next round that there are no digits left, and the attempt to read past the end of the stream makes the stream "fail", which is the exit condition for the loop. Here's a demo.
2 年多之前 回复
csdnceshi80
胖鸭 One clarification please, in the first approach, as i understand, >> returns the reference to the stream object. So the question is when the stream reaches eof what will be returned that makes the while loop break.
2 年多之前 回复
weixin_41568174
from.. You can't do it in the first approach, which assumes you're parsing tokens and doesn't know what a "line" is. It's trivial in the second approach, where you just check the first character of the line string (potentially skipping whitespace).
2 年多之前 回复
csdnceshi71
Memor.の What's the best way to skip "#" commented lines use the first or second approach? Thanks.
2 年多之前 回复
csdnceshi54
hurriedly% enjoy your cold one
接近 3 年之前 回复
weixin_41568174
from.. thatched :-)
接近 3 年之前 回复
csdnceshi54
hurriedly% peasant quest command make friends with @KerrekSB
接近 3 年之前 回复
csdnceshi50
三生石@ For an explanation of the while(getline(f, line)) { } construct and regarding error handling please have a look at this (my) article: gehrcke.de/2011/06/… (I think I do not need to have bad conscience posting this here, it even slightly pre-dates this answer).
5 年多之前 回复
csdnceshi51
旧行李 Huh. I was wrong. I didn't know it could do that. I might have some code of my own to rewrite.
5 年多之前 回复
weixin_41568174
from.. Are you sure?
5 年多之前 回复
csdnceshi51
旧行李 That would only work if the comma was surrounded by spaces, i.e., "1 , 2". If the line contained "1,2", then your code would try to convert "1,2" into an integer (storing it in a) while c and b would get the tokens/delimiters on the next line. With anything besides whitespace delimiters, you really need to use std::getline() and parse the line.
5 年多之前 回复
weixin_41568174
from.. Ah, so when you said "token" you meant "delimiter". Right. With a comma, you'd say: int a, b; char c; while ((infile >> a >> c >> b) && (c == ','))
5 年多之前 回复
weixin_41568127
?yb? the OP used a space to delimit the two integers. I wanted to know if while (infile >> a >> b) would work if the OP used a as a comma a delimiter, because that is the scenario in my own program
5 年多之前 回复
weixin_41568174
from.. I don't understand what "commas as the token" means. Commas don't represent integers.
5 年多之前 回复
weixin_41568127
?yb? Will solution #1 work with commas as the token?
5 年多之前 回复

Use ifstream to read data from a file:

std::ifstream input( "filename.ext" );

If you really need to read line by line, then do this:

for( std::string line; getline( input, line ); )
{
    ...for each line in input...
}

But you probably just need to extract coordinate pairs:

int x, y;
input >> x >> y;

Update:

In your code you use ofstream myfile;, however the o in ofstream stands for output. If you want to read from the file (input) use ifstream. If you want to both read and write use fstream.

weixin_41568134
MAO-EYE getline is in string see, so don't forget the #include <string>
接近 3 年之前 回复
weixin_41568208
北城已荒凉 Your solution is a bit improved: your line variable is not visible after file read-in in contrast to Kerrek SB's second solution which is good and simple solution too.
接近 7 年之前 回复

Reading a file line by line in C++ can be done in some different ways.

[Fast] Loop with std::getline()

The simplest approach is to open an std::ifstream and loop using std::getline() calls. The code is clean and easy to understand.

#include <fstream>

std::ifstream file(FILENAME);
if (file.is_open()) {
    std::string line;
    while (getline(file, line)) {
        // using printf() in all tests for consistency
        printf("%s", line.c_str());
    }
    file.close();
}

[Fast] Use Boost's file_description_source

Another possibility is to use the Boost library, but the code gets a bit more verbose. The performance is quite similar to the code above (Loop with std::getline()).

#include <boost/iostreams/device/file_descriptor.hpp>
#include <boost/iostreams/stream.hpp>
#include <fcntl.h>

namespace io = boost::iostreams;

void readLineByLineBoost() {
    int fdr = open(FILENAME, O_RDONLY);
    if (fdr >= 0) {
        io::file_descriptor_source fdDevice(fdr, io::file_descriptor_flags::close_handle);
        io::stream <io::file_descriptor_source> in(fdDevice);
        if (fdDevice.is_open()) {
            std::string line;
            while (std::getline(in, line)) {
                // using printf() in all tests for consistency
                printf("%s", line.c_str());
            }
            fdDevice.close();
        }
    }
}

[Fastest] Use C code

If performance is critical for your software, you may consider using the C language. This code can be 4-5 times faster than the C++ versions above, see benchmark below

FILE* fp = fopen(FILENAME, "r");
if (fp == NULL)
    exit(EXIT_FAILURE);

char* line = NULL;
size_t len = 0;
while ((getline(&line, &len, fp)) != -1) {
    // using printf() in all tests for consistency
    printf("%s", line);
}
fclose(fp);
if (line)
    free(line);

Benchmark -- Which one is faster?

I have done some performance benchmarks with the code above and the results are interesting. I have tested the code with ASCII files that contain 100,000 lines, 1,000,000 lines and 10,000,000 lines of text. Each line of text contains 10 words in average. The program is compiled with -O3 optimization and its output is forwarded to /dev/null in order to remove the logging time variable from the measurement. Last, but not least, each piece of code logs each line with the printf() function for consistency.

The results show the time (in ms) that each piece of code took to read the files.

The performance difference between the two C++ approaches is minimal and shouldn't make any difference in practice. The performance of the C code is what makes the benchmark impressive and can be a game changer in terms of speed.

                             10K lines     100K lines     1000K lines
Loop with std::getline()         105ms          894ms          9773ms
Boost code                       106ms          968ms          9561ms
C code                            23ms          243ms          2397ms

enter image description here

csdnceshi54
hurriedly% Groovy. Thanks. Wonder where the slowdown is.
接近 2 年之前 回复
weixin_41568174
from.. Thanks for bringing this concern. I've redone the tests and the performance is still the same. I have edited the code to use the printf() function in all cases for consistency. I have also tried using std::cout in all cases and this made absolutely no difference. As I have just described in the text, the output of the program goes to /dev/null so the time to print the lines is not measured.
接近 2 年之前 回复
csdnceshi54
hurriedly% What happens if you remove C++'s synchronization with C on the console outputs? You might be measuring a known disadvantage of the default behavior of std::cout vs printf.
接近 2 年之前 回复

Expanding on the accepted answer, if the input is:

1,NYC
2,ABQ
...

you will still be able to apply the same logic, like this:

#include <fstream>

std::ifstream infile("thefile.txt");
if (infile.is_open()) {
    int number;
    std::string str;
    char c;
    while (infile >> number >> c >> str && c == ',')
        std::cout << number << " " << str << "\n";
}
infile.close();

Since your coordinates belong together as pairs, why not write a struct for them?

struct CoordinatePair
{
    int x;
    int y;
};

Then you can write an overloaded extraction operator for istreams:

std::istream& operator>>(std::istream& is, CoordinatePair& coordinates)
{
    is >> coordinates.x >> coordinates.y;

    return is;
}

And then you can read a file of coordinates straight into a vector like this:

#include <fstream>
#include <iterator>
#include <vector>

int main()
{
    char filename[] = "coordinates.txt";
    std::vector<CoordinatePair> v;
    std::ifstream ifs(filename);
    if (ifs) {
        std::copy(std::istream_iterator<CoordinatePair>(ifs), 
                std::istream_iterator<CoordinatePair>(),
                std::back_inserter(v));
    }
    else {
        std::cerr << "Couldn't open " << filename << " for reading\n";
    }
    // Now you can work with the contents of v
}
csdnceshi61
derek5. in the operator>> it is more correct to say is >> std::ws >> coordinates.x >> std::ws >> coordinates.y >> std::ws; since otherwise you are assuming that your input stream is in the whitespace-skipping mode.
3 年多之前 回复
csdnceshi80
胖鸭 If it's not possible to read two int tokens, then the is stream will evaluate to false and the reading loop will terminate at that point. You can detect this within operator>> by checking the return value of the individual reads. If you want to roll back the stream, you would call is.clear().
3 年多之前 回复
csdnceshi70
笑故挽风 What happens when it's not possible to read two int tokens from the stream in operator>>? How can one make it work with a backtracking parser (i.e. when operator>> fails, roll back the stream to previous position end return false or something like that)?
3 年多之前 回复

Although there is no need to close the file manually but it is good idea to do so if the scope of the file variable is bigger:

    ifstream infile(szFilePath);

    for (string line = ""; getline(infile, line); )
    {
        //do something with the line
    }

    if(infile.is_open())
        infile.close();

with command line arguments:

#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>
#include "print.h"

using namespace std;

int main (int argc, char *argv[]) 
{
    vector<string> list;
    ifstream in_stream;
    string line;
    in_stream.open(argv[1]);

    while(!in_stream.eof())
    {
        in_stream >> line;
        list.push_back(line);
    }
    in_stream.close();
    print(list);
    sort(list.begin(), list.end());
    print(list);
}
csdnceshi70
笑故挽风 On top of that this doesn't even answer the question. It doesn't process the data line by line and doesn't view each line as a set of coordinates.
大约 5 年之前 回复
csdnceshi70
笑故挽风 Please fix the broken loop on eof(): stackoverflow.com/questions/5605125/… In addition to looping on eof() you don't bother to check if your read succeeds before putting its value in the vector.
大约 5 年之前 回复
weixin_41568184
叼花硬汉 To explain while(!in_stream.eof()): say the last line contains "12 4\n" (per question), when your loop's >> line reads "4", it will recognise the \n as white-space delimiting the value "4" and stop with the input position at that final newline, but will not yet have tried to go beyond the newline; eof() will not have been set. So, when your while loop tests eof() it thinks there's more input, calls in_stream >> line; again but you don't test for the failure: in C++03 line is unspecified, in C++11 I think "". Either way, you push_back one repeat or garbage string.
大约 5 年之前 回复
csdnceshi53
Lotus@ I would suggest using getline here also. The above delimits the input based on any whitespaces which may not be desired while getline() has default delimiter '\n'
大约 6 年之前 回复
weixin_41568208
北城已荒凉 Good, but it will fail in many other cases. It's better to do while (in_stream >> line).
6 年多之前 回复
csdnceshi58
Didn"t forge compiled and ran on windows Visual Studio
6 年多之前 回复
weixin_41568208
北城已荒凉 while (!file.eof()) is wrong.
6 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
在 c + + 中使用 ifstream 逐行读取文件

<div class="post-text" itemprop="text"> <p>The contents of file.txt are:</p> <pre><code>5 3 6 4 7 1 10 5 11 6 12 3 12 4 </code></pre> <p>Where <code>5 3</code> is a coordinate pair. How do I process this data line by line in C++?</p> <p>I am able to get the first line, but how do I get the next line of the file?</p> <pre><code>ifstream myfile; myfile.open ("text.txt"); </code></pre> </div> <p>转载于:https://stackoverflow.com/questions/7868936/read-file-line-by-line-using-ifstream-in-c</p>

c++有没有类似qt这种逐行读取txt文件的方式

while (!file.atEnd()) { line = file.readLine(); ui->label->setText(line); line = line + "\n"; arr = arr + line; ui->label->setText(arr); } 没有没类似这种的额

如何知道c++的文件读取流ifstream当前读取的位置?

我知道如果要定位ifstream的位置可以用诸如ifstream.seekg(offset, ios::cur)这样的方法,但是我想知道ifstream当前读取的位置怎么写呢?这是个现实的需求,我必须先得到这个位置,然后读取线程退出,再启动读取线程时用上面的seekg方法定位到之前的位置继续读取下去,我觉得这是一个挺普通的功能需求,ifstream类应该已经提供了现成方法的吧??怎么写呢?望高手指教!

C++使用ifstream如何获取文件长度(具体数值)

rt,如何获取一个文件的实际长度(字节即可),但是我不是要打印在屏幕上,而是要存在 long long型的变量里面。网上给的streampos的方法虽然能得到长度但是,无法将长度转存到一个long long型里面(强转是木有用的),虽然streampos里面有个Fpos正好能指示长度然而不幸的是人家是私有的,无法读取。所以还请大神帮帮忙,要用ifstream,并且能够读取文件长度,多谢。

c++逐行读取txt文件getline漏掉第一行

#include<iostream> #include<string> #include<fstream> using namespace std; int main() { ifstream fin; fin.open("word.txt"); string str; while (!fin.eof()) { getline(fin, str); fin >> str; cout << str<< endl; } fin.close(); } word.txt第一行始终显示不出来。求解

ifstream读取多个文件

``` void readfile(string str, vector <int> &v) { ifstream inputFile; int num; inputFile.open(str.c_str()); if (inputFile) { while (inputFile >> num) { v.push_back(num); } } else { cout << "Can not open the file" << endl; } inputFile.close(); inputFile.clear();//// } ``` 想用readfile函数读多次文件存储到vector里,为什么只有第一个文件可以读,后面的都不行 ``` readfile(filename_ori, ori_vect); readfile(filename_first, first_vect); readfile(filename_second, second_vect); readfile(filename_third, third_vect); ```

C++如何读取文件创建链表,用ifstream和ofstream来做?

各位大佬,麻烦看看这题怎么做? C++期末成绩存放在文本文件 “Score.txt”中,要求编写程序读取该文本文件创建链表,并在链表上根据学号查找姓名和成绩。 文本文件的各列之间使用空格分隔,文件行数不确定。 **要求使用ifstream类和ofstream类的对象读取和写入数据**。 链表的一个结点可声明如下: struct student { unsigned long id; string name; float score; student *next; //下一个结点的指针 } 循环从键盘读入学号,查询对应的姓名和成绩,输入学号为0时退出循环。

ifstream读取错误,求解

我文件中有“&”,但是他好像读的有问题,无法进行调试 提取了片段 ``` #include<iostream> #include<fstream> #include<cstring> using namespace std; int main() { string c; ifstream filein("密码.txt",ios::in); while(getline(filein,c)) { if(c=="&") { flag=1; continue; } if(flag==1) { cout<<c<<endl; break; } } return 0; } ``` 密码.txt中: & awdrgy 16827 17234 23424 ...... 为什么它输出为空白?

MFC 使用ifstream读取文件的时候“<<”不合法什么鬼

if (openFile(&fread, file)) { int count1 = 0; for (int count = 0; count < ROW; count++){ fread >> str >> a[0] >> a[1] >> a[2]; data[count1] = a[0]; data[count1 + 1] = a[1]; data[count1 + 2] = a[2]; count1 += 3; } error C2678: binary '>>' : no operator defined which takes a left-hand operand of type 'class ifstream' (or there is no acceptable conversion)

从txt文件中读取数据存入到链表,即使文件没有内容也会存上数字和乱码

代码如下: ``` contacts* read(char* filename)//把文件读入链表 { FILE* fp; if ((fp = fopen("people.txt","r")) == NULL)//以可读写方式打开文件,如果没有则建立一个 { printf ("文件打开失败!\n"); exit (1); } contacts *head, *q, *p, *h; head = NULL; p = (contacts*)malloc(sizeof(contacts)); if(NULL == p) { printf("内存分配错误"); exit(1); } q = p; //开始时,p和q均指向第1个结点 while (!feof(fp))//创建链表, 并把文件内容输入 { n++; if (n == 1) { head = p; } else { q->next = p; } q = p;//q是最后一个结点 p = (contacts*)malloc(sizeof(contacts)); fscanf(fp,"%d %s %s",&p->no,&p->name,&p->sex); /*int i=0; for(i=0;i<8;i++) { fscanf(fp,"%s",&p->phonenumber[i]); } fscanf(fp,"%s %d %d %d",&p->address,&p->byear,&p->bmonth,&p->bday);*/ }; q->next = NULL;//输入完毕后,q->next为NULL h = head; fclose(fp); return h; } void browse(contacts* head)//显示程序中所有记录的信息。 { while(head)//当head不为空的时候 { printf("\n==================================\ \n序号:%d\ \n姓名:%s 性别:%s",head->no,head->name,head->sex); /*printf("\n电话号码:\n"); int i; for(i=0; i<8; i++) { if(strlen(head->phonenumber[i]) == 0) { continue; } else { printf("%s\n",head->phonenumber[i]); } } printf("住址:%s ",head->address); printf("生日:%d年%d月%d日",head->byear,head->bmonth,head->bday);*/ printf("\n==================================\n"); head = head->next; } } ``` 运行结果 ![图片说明](https://img-ask.csdn.net/upload/201903/02/1551542218_627768.jpg) 为啥会这样。

C ++:提高ifstream二进制文件的读取速度

<div class="post-text" itemprop="text"> <p>I am rewriting small program from PHP to C++. The idea is basically to read through 32Gb file on an SSD and do some simple operations on it. </p> <p>I am using Visual Studio 2012 with x64 release build. PHP is 5.3 32bit. </p> <p>The problem is that bare reading speed in PHP is higher, than in C++, and this really puzzles me. PHP does ~350 Mb/s and C++/ifstream code does 180 Mb/sec.</p> <p>Code is really simple: </p> <pre><code>ifstream datafile("data.txt", ios::binary); while(datafile.read((char*)buffer, data_per_chunk)) { // do stuff; </code></pre> <p>I've tried different buffer sizes up to 16Mb and it did little difference. I also tried to set internal buffer via datafile.rdbuf()-&gt;pubsetbuf(...) but it also didn't made a difference. </p> <p>Is there any hints on how to speed ifstream up without reverting to ancient C-level interface? I would like to at least reach PHP level of performance. Maybe some fancy read-ahead / cache settings or something. </p> <p>I understand that memory-mapped files could likely help, but would prefer to tweak settings of ifstream, if it's possible to keep things simple given that file is significantly larger than physical RAM and larger than 4Gb i.e. no-go for potential 32-bit builds.</p> </div>

ifstream读取错误,求解?

我不明白为什么会发生这样,求解!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! ``` #include//bits/stdc++.h #include//help.h cin>>name; string c; ifstream filein14("情况.txt",ios::in); while(getline(filein14,c)) { length_word[flag]=c.length()-1; debug(length_word[flag]); flag+=1; if(c==name) { flag2=1; break; } } ``` help.h的内容: ``` #include//bits/stdc++.h using namespace std; void debug(int a) { cout<<a<<endl; } void debug(char a) { cout<<a<<endl; } void debug(char* a) { cout<<a<<endl; } void debug(string a) { cout<<a<<endl; } ``` 情况.txt的内容(有部分中文乱码): ``` awdrgy #1.0#3-3 dorothy #2.2#0-0 sssusie #1.0#3-0 ߴߴ #1.0#4-0 perry #4.0#7-2 Ʈ������ #4.0#7-0 ``` 输出: ``` 8 7 6 7 6 7 3 7 4 ``` 解释:我输出了文件每行的长度 谁能告诉我为什么?

C语言二进制文件读写异常

``` #include <stdio.h> int main() { FILE* fp = fopen("D:\\计算机\\VSdemo\\CPUdemo\\dict.dic2", "rb"); unsigned int x; fread(&x, sizeof(x), 1, fp); printf("%u", x); } ``` 想写一个读取二进制数的程序,文件中的二进制数是00001011000100000000000000000000,输出是808464432,实在不明白

关于C++中的ifstream用法

用accumulate求一个vectoe<int>中的所有元素之和,程序如下: #include<iostream> #include<fstream> #include<vector> #include<numeric> using namespace std; int main(int argc,char *argv[]) { ifstream in(argv[1]); if (!in){ cout << "打开文件失败" << endl; exit(1); } vector<int> vi; int val; while (in >> val) vi.push_back(val); cout << "序列中的整数之和为:" << accumulate(vi.begin(), vi.end(), val) << "个" << val; system("pause"); return 0; } 编译后出现错误: ![图片说明](https://img-ask.csdn.net/upload/201608/13/1471052289_842015.jpg) 请问这是怎么回事?想用ifstream打开一个文件,文件应该是什么格式?是否应该放置在project文件夹中?

请问txt文件应该放在哪个文件夹

我有个程序,是用来处理txt文件的,需要控制台输入文件名字, 也就是用这个int main(int argc, const char*argv[]) 用vs2017编译成功后,我把txt文件放在相应目录下, 就是放vcxproj文件的那个文件夹 没有问题,可以打开文件和读取 之后关了vs2017后 然后我用cmd打开exe文件,然后再接着输入: 文件名.txt 然后就显示找不到这个txt文件了 之后又尝试输入txt文件的绝对路径就又可以了 所以感觉的txt文件放的位置不对 想请教一下各位大佬 到底放在哪个文档才可以直接输入txt文件名就能打开! ![图片说明](https://img-ask.csdn.net/upload/202003/20/1584684228_240936.png) ![图片说明](https://img-ask.csdn.net/upload/202003/20/1584684256_857462.png)

C++读取文件流失败的原因?

``` #include "pch.h" #include <iostream> #include<fstream> using namespace std; int main() { char N[20]; string str("iostream_exercise.txt"); ifstream in(str); in.open(str); if (in.is_open()) in >> N; else cout << "读取失败" << endl; for (int j = 0; j < 20; j++) { cout << N[j] << " "; } in.close(); } ``` 文本文件内容是:woaini 文本文件编码方式为ANSI 放在了本工程文件内,运行在VS2017。 输出: 读取失败 ??????????????????? 请赐教,感谢! 请赐教!

4小时玩转微信小程序——基础入门与微信支付实战

这是一个门针对零基础学员学习微信小程序开发的视频教学课程。课程采用腾讯官方文档作为教程的唯一技术资料来源。杜绝网络上质量良莠不齐的资料给学员学习带来的障碍。 视频课程按照开发工具的下载、安装、使用、程序结构、视图层、逻辑层、微信小程序等几个部分组织课程,详细讲解整个小程序的开发过程

Python可以这样学(第四季:数据分析与科学计算可视化)

董付国老师系列教材《Python程序设计(第2版)》(ISBN:9787302436515)、《Python可以这样学》(ISBN:9787302456469)配套视频,在教材基础上又增加了大量内容,通过实例讲解numpy、scipy、pandas、statistics、matplotlib等标准库和扩展库用法。

组成原理课程设计(实现机器数的真值还原等功能)

实现机器数的真值还原(定点小数)、定点小数的单符号位补码加减运算、定点小数的补码乘法运算和浮点数的加减运算。

javaWeb图书馆管理系统源码mysql版本

系统介绍 图书馆管理系统主要的目的是实现图书馆的信息化管理。图书馆的主要业务就是新书的借阅和归还,因此系统最核心的功能便是实现图书的借阅和归还。此外,还需要提供图书的信息查询、读者图书借阅情况的查询等

土豆浏览器

土豆浏览器可以用来看各种搞笑、电影、电视剧视频

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

TTP229触摸代码以及触摸返回值处理

自己总结的ttp229触摸代码,触摸代码以及触摸按键处理

网络工程师小白入门--【思科CCNA、华为HCNA等网络工程师认证】

本课程适合CCNA或HCNA网络小白同志,高手请绕道,可以直接学习进价课程。通过本预科课程的学习,为学习网络工程师、思科CCNA、华为HCNA这些认证打下坚实的基础! 重要!思科认证2020年2月24日起,已启用新版认证和考试,包括题库都会更新,由于疫情原因,请关注官网和本地考点信息。题库网络上很容易下载到。

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

java jdk 8 帮助文档 中文 文档 chm 谷歌翻译

JDK1.8 API 中文谷歌翻译版 java帮助文档 JDK API java 帮助文档 谷歌翻译 JDK1.8 API 中文 谷歌翻译版 java帮助文档 Java最新帮助文档 本帮助文档是使用谷

Ubuntu18.04安装教程

Ubuntu18.04.1安装一、准备工作1.下载Ubuntu18.04.1 LTS2.制作U盘启动盘3.准备 Ubuntu18.04.1 的硬盘空间二、安装Ubuntu18.04.1三、安装后的一些工作1.安装输入法2.更换软件源四、双系统如何卸载Ubuntu18.04.1新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列...

快速排序---(面试碰到过好几次)

原理:    快速排序,说白了就是给基准数据找其正确索引位置的过程.    如下图所示,假设最开始的基准数据为数组第一个元素23,则首先用一个临时变量去存储基准数据,即tmp=23;然后分别从数组的两端扫描数组,设两个指示标志:low指向起始位置,high指向末尾.    首先从后半部分开始,如果扫描到的值大于基准数据就让high减1,如果发现有元素比该基准数据的值小(如上图中18&amp;lt...

手把手实现Java图书管理系统(附源码)

【超实用课程内容】 本课程演示的是一套基于Java的SSM框架实现的图书管理系统,主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的java人群。详细介绍了图书管理系统的实现,包括:环境搭建、系统业务、技术实现、项目运行、功能演示、系统扩展等,以通俗易懂的方式,手把手的带你从零开始运行本套图书管理系统,该项目附带全部源码可作为毕设使用。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/27513 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/27513,点击右下方课程资料、代码、课件等打包下载

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

C++语言基础视频教程

C++语言基础视频培训课程:本课与主讲者在大学开出的程序设计课程直接对接,准确把握知识点,注重教学视频与实践体系的结合,帮助初学者有效学习。本教程详细介绍C++语言中的封装、数据隐藏、继承、多态的实现等入门知识;主要包括类的声明、对象定义、构造函数和析构函数、运算符重载、继承和派生、多态性实现等。 课程需要有C语言程序设计的基础(可以利用本人开出的《C语言与程序设计》系列课学习)。学习者能够通过实践的方式,学会利用C++语言解决问题,具备进一步学习利用C++开发应用程序的基础。

UnityLicence

UnityLicence

软件测试2小时入门

本课程内容系统、全面、简洁、通俗易懂,通过2个多小时的介绍,让大家对软件测试有个系统的理解和认识,具备基本的软件测试理论基础。 主要内容分为5个部分: 1 软件测试概述,了解测试是什么、测试的对象、原则、流程、方法、模型;&nbsp; 2.常用的黑盒测试用例设计方法及示例演示;&nbsp; 3 常用白盒测试用例设计方法及示例演示;&nbsp; 4.自动化测试优缺点、使用范围及示例‘;&nbsp; 5.测试经验谈。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

Python数据分析师-实战系列

系列课程主要包括Python数据分析必备工具包,数据分析案例实战,核心算法实战与企业级数据分析与建模解决方案实战,建议大家按照系列课程阶段顺序进行学习。所有数据集均为企业收集的真实数据集,整体风格以实战为导向,通俗讲解Python数据分析核心技巧与实战解决方案。

YOLOv3目标检测实战系列课程

《YOLOv3目标检测实战系列课程》旨在帮助大家掌握YOLOv3目标检测的训练、原理、源码与网络模型改进方法。 本课程的YOLOv3使用原作darknet(c语言编写),在Ubuntu系统上做项目演示。 本系列课程包括三门课: (1)《YOLOv3目标检测实战:训练自己的数据集》 包括:安装darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 (2)《YOLOv3目标检测:原理与源码解析》讲解YOLOv1、YOLOv2、YOLOv3的原理、程序流程并解析各层的源码。 (3)《YOLOv3目标检测:网络模型改进方法》讲解YOLOv3的改进方法,包括改进1:不显示指定类别目标的方法 (增加功能) ;改进2:合并BN层到卷积层 (加快推理速度) ; 改进3:使用GIoU指标和损失函数 (提高检测精度) ;改进4:tiny YOLOv3 (简化网络模型)并介绍 AlexeyAB/darknet项目。

超详细MySQL安装及基本使用教程

一、下载MySQL 首先,去数据库的官网http://www.mysql.com下载MySQL。 点击进入后的首页如下:  然后点击downloads,community,选择MySQL Community Server。如下图:  滑到下面,找到Recommended Download,然后点击go to download page。如下图:  点击download进入下载页面选择No...

一学即懂的计算机视觉(第一季)

图像处理和计算机视觉的课程大家已经看过很多,但总有“听不透”,“用不了”的感觉。课程致力于创建人人都能听的懂的计算机视觉,通过生动、细腻的讲解配合实战演练,让学生真正学懂、用会。 【超实用课程内容】 课程内容分为三篇,包括视觉系统构成,图像处理基础,特征提取与描述,运动跟踪,位姿估计,三维重构等内容。课程理论与实战结合,注重教学内容的可视化和工程实践,为人工智能视觉研发及算法工程师等相关高薪职位就业打下坚实基础。 【课程如何观看?】 PC端:https://edu.csdn.net/course/detail/26281 移动端:CSDN 学院APP(注意不是CSDN APP哦) 本课程为录播课,课程2年有效观看时长,但是大家可以抓紧时间学习后一起讨论哦~ 【学员专享增值服务】 源码开放 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 下载方式:电脑登录https://edu.csdn.net/course/detail/26281,点击右下方课程资料、代码、课件等打包下载

董付国老师Python全栈学习优惠套餐

购买套餐的朋友可以关注微信公众号“Python小屋”,上传付款截图,然后领取董老师任意图书1本。

爬取妹子图片(简单入门)

安装第三方请求库 requests 被网站禁止了访问 原因是我们是Python过来的 重新给一段 可能还是存在用不了,使用网页的 编写代码 上面注意看匹配内容 User-Agent:请求对象 AppleWebKit:请求内核 Chrome浏览器 //请求网页 import requests import re //正则表达式 就是去不规则的网页里面提取有规律的信息 headers = { 'User-Agent':'存放浏览器里面的' } response = requests.get

web网页制作期末大作业

分享思维,改变世界. web网页制作,期末大作业. 所用技术:html css javascript 分享所学所得

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

Spring Boot -01- 快速入门篇(图文教程)

Spring Boot -01- 快速入门篇 今天开始不断整理 Spring Boot 2.0 版本学习笔记,大家可以在博客看到我的笔记,然后大家想看视频课程也可以到【慕课网】手机 app,去找【Spring Boot 2.0 深度实践】的课程,令人开心的是,课程完全免费! 什么是 Spring Boot? Spring Boot 是由 Pivotal 团队提供的全新框架。Spring Boot...

立方体线框模型透视投影 (计算机图形学实验)

计算机图形学实验 立方体线框模型透视投影 的可执行文件,亲测可运行,若需报告可以联系我,期待和各位交流

Python数据清洗实战入门

本次课程主要以真实的电商数据为基础,通过Python详细的介绍了数据分析中的数据清洗阶段各种技巧和方法。

软件测试入门、SQL、性能测试、测试管理工具

软件测试2小时入门,让您快速了解软件测试基本知识,有系统的了解; SQL一小时,让您快速理解和掌握SQL基本语法 jmeter性能测试 ,让您快速了解主流来源性能测试工具jmeter 测试管理工具-禅道,让您快速学会禅道的使用,学会测试项目、用例、缺陷的管理、

相关热词 c# cad插入影像 c#设计思想 c#正则表达式 转换 c#form复制 c#写web c# 柱形图 c# wcf 服务库 c#应用程序管理器 c#数组如何赋值给数组 c#序列化应用目的博客园
立即提问