Tag: file io

在不知道行长的情况下从文件中读取行

我想逐行阅读文件,而不知道行长。 这是我到目前为止: int ch = getc(file); int length = 0; char buffer[4095]; while (ch != '\n' && ch != EOF) { ch = getc(file); buffer[length] = ch; length++; } printf("Line length: %d characters.", length); char newbuffer[length + 1]; for (int i = 0; i < length; i++) newbuffer[i] = buffer[i]; newbuffer[length] = '\0'; // newbuffer […]

C函数在文件中的特定位置插入文本,而不会覆盖现有的文本

我写了一个程序,它将一个文件作为input,并且每当它find一个长度大于80的行时,它就会将\和\ n添加到该文件中,使其最大宽度为80个字符。 问题是我已经使用fseek插入\和\ n每当长度超过80,所以它覆盖该行超过长度80的两个字符。有没有一种方法,我可以插入文本,而不会覆盖现有的文本? 这是我的代码: #include<stdio.h> #include<string.h> int main(int argc, char *argv[]) { FILE *fp1,*fp2; int prev=0,now=0; char ch; int flag=0; long cur; fp1=fopen(argv[1],"r+"); if(fp1==NULL){ printf("Unable to open the file to read. Program will exit."); exit(0); } else{ while((ch=fgetc(fp1))!=EOF){ if(ch!=' ' && ch!='\n'){ now=now+1; } else{ if(now>=80){ fseek(fp1,cur,SEEK_SET); fputc('\\',fp1); fputc('\n',fp1); now=0; continue; } if(ch=='\n'){ flag=0; […]

从C语言的文件中删除一行

我想删除文件中的某些行,并根据行的某些部分是否与指定的string匹配,在同一个文件中插入某些行。 有没有办法做到这一点,而不使用临时文件复制内容等等?

Java BufferedReader回到文本文件的顶部?

我目前有2个BufferedReader初始化在同一个文本文件。 当我用第一个BufferedReader读取文本文件时,我使用第二个文件从顶部再次传递文件。 多次通过相同的文件是必要的。 我知道关于reset() ,但它需要先调用mark()和mark()需要知道文件的大小,我不认为我应该打扰。 想法? 包? 库? 码? 谢谢TJ

尝试在Android中创build文件:打开失败:EROFS(只读文件系统)

这一行: final FileOutputStream outputStream = new FileOutputStream(name); 导致FileNotFoundException ,消息是/2ozjfFQzwv: open failed: EROFS (Read-only file system)其中“2ozjfFQzwv”是我作为文件的名称传递的。 我已经试过这个和没有WRITE_INTERNAL_STORAGE权限。 我如何创build这个文件的写作? 另外,我只是希望能够给一个新的活动提供一个图像,而且它太大而无法在一个额外的序列化中。 有没有比写入文件,然后再读取一个更简单的方法? 这里的所有问题似乎都是关于写入SD卡,我不想这样做,因为很多人没有SD卡插槽。

如何在Python中一次读取N行文件?

我需要一次读至多N行,直到EOF读大文件。 什么是在Python中最有效的方法? 就像是: with open(filename, 'r') as infile: while not EOF: lines = [get next N lines] process(lines)

使用Python进行内嵌CSV文件编辑

我可以使用Python的CSV库或类似的技术来内嵌CSV文件吗? 目前,我正在处理一个文件并更新第一列(名称字段)以更改格式。 我的代码的简化版本如下所示: with open('tmpEmployeeDatabase-out.csv', 'w') as csvOutput: writer = csv.writer(csvOutput, delimiter=',', quotechar='"') with open('tmpEmployeeDatabase.csv', 'r') as csvFile: reader = csv.reader(csvFile, delimiter=',', quotechar='"') for row in reader: row[0] = row[0].title() writer.writerow(row) 哲学的作品,但我很好奇,如果我可以做一个内联编辑,以便我不复制该文件。 我已经试过了,但是这会将新logging追加到文件的末尾而不是replace它们。 with open('tmpEmployeeDatabase.csv', 'r+') as csvFile: reader = csv.reader(csvFile, delimiter=',', quotechar='"') writer = csv.writer(csvFile, delimiter=',', quotechar='"') for row in reader: row[1] = row[1].title() […]

如何使用UTF-8编码保存源().R文件?

以下,直接复制并粘贴到R工作正常: > character_test <- function() print("R同时也被称为GNU S是一个强烈的function性语言和环境,探索统计数据集,使许多从自定义数据graphics显示…") > character_test() [1] "R同时也被称为GNU S是一个强烈的function性语言和环境,探索统计数据集,使许多从自定义数据graphics显示…" 但是,如果我创build了一个名为character_test.R的文件,其中包含EXACT SAME代码, 请将其保存为UTF-8编码 (以保留特殊的中文字符),然后当我在R中源代码时,出现以下错误: > source(file="C:\\Users\\Tony\\Desktop\\character_test.R", encoding = "UTF-8") Error in source(file = "C:\\Users\\Tony\\Desktop\\character_test.R", encoding = "utf-8") : C:\Users\Tony\Desktop\character_test.R:3:0: unexpected end of input 1: character.test <- function() print("R 2: ^ In addition: Warning message: In source(file = "C:\\Users\\Tony\\Desktop\\character_test.R", encoding = "UTF-8") : invalid […]

我如何读取文本文件而不locking它?

我有一个Windows服务以简单的格式将其日志写入文本文件。 现在,我将创build一个小应用程序来读取服务的日志,并将现有日志和添加的日志显示为实时视图。 问题是该服务locking文本文件以添加新行,同时查看器应用程序locking文件以供阅读。 服务代码: void WriteInLog(string logFilePath, data) { File.AppendAllText(logFilePath, string.Format("{0} : {1}\r\n", DateTime.Now, data)); } 查看器代码: int index = 0; private void Form1_Load(object sender, EventArgs e) { try { using (StreamReader sr = new StreamReader(logFilePath)) { while (sr.Peek() >= 0) // reading the old data { AddLineToGrid(sr.ReadLine()); index++; } sr.Close(); } timer1.Start(); } catch […]

Java FileOutputStream创build文件如果不存在

有没有办法使用FileOutputStream的方式,如果一个文件(string文件名)不存在,那么它会创build它? FileOutputStream oFile = new FileOutputStream("score.txt", false);