- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这样我就可以完成(不完全正确,但对我来说很好)一个名为 order.txt 的文件的内容列表
该文件具有以下内容
假设我们当前的时间是14:59
order.txt
file1.txt;5;15:00
file2.txt;6;15:01
file3.txt;7;15:02
file1.txt;2;15:03
file1.txt;5;15:05
file2.txt;2;15:06
file1.txt;3;15:07
所以基本上,“文件名”;“列出 X 秒”;“从 ##:## 开始列出”
该文件将打开,然后按照上面给出的顺序列出所有内容,直到完成为止。
但是,现在我需要在使用时保存每个文件,包括它的总列表数、列出的总时间,以及是否有列出时间(基本上,如果它在 order.txt 中)。 txt 文件)
例如,它应该是这样的:
used.txt
file1.txt;4;15;1 (1 - Is in the order.txt, 0 - Its not, I can do this one after this is done, it will change when I remove it's time)
file2.txt;2;8;1
file3.txt;1;7;1
基本上,“fileName”;“totalTimeItAppears”;“totalSecondsItShows”;“IfItIsInOrder.txt”
并且,如果用户决定再次显示 order.txt 并且它仍然保持不变,当然,它需要再次更新并且将具有新值(在这种情况下将是上述值的两倍)
used.txt
file1.txt;8;30;1
file2.txt;4;16;1
file3.txt;2;14;1
我已经尝试过执行我的代码,但它只在第一次起作用,并且可能只有在有两次相同的值时才起作用,在这种情况下,file1.txt 显示了 4 次,因此它可能不起作用,所以我删除了代码。我尝试过考虑不同的方法,但无法找到正确更新它的想法。
这是我显示 order.txt 的代码:
orderFile = fopen("order.txt","r");
if(orderFile != NULL)
{
fseek(orderFile, 0, SEEK_END);
size = ftell(orderFile);
rewind(orderFile);
if(size == 0)
{
printf("\n< No files to list >\n\n");
fclose(orderFile);
}
else
{
while(fscanf(orderFile," %49[^;];%d; %49[^\n]\n",fileName,&seconds,timeValue) == 3)
{
contentFile = fopen(fileName,"r");
if(contentFile != NULL)
{
sscanf(timeValue,"%d:%d",&hour,&min);
fseek(contentFile, 0, SEEK_END);
size = ftell(contentFile);
rewind(contentFile);
if(size == 0)
{
printf("\n< Scanned File has nothing to list >\n\n");
fclose(contentFile);
}
else
{
time_t now;
time(&now);
struct tm file_time_tm;
file_time_tm = *localtime(&now);
file_time_tm.tm_hour = hour;
file_time_tm.tm_min = min;
file_time_tm.tm_sec = 0;
file_time_tm.tm_isdst = -1;
time_t fileTime = mktime(&file_time_tm);
diff_time = difftime(fileTime, now);
if(diff_time > 0)
{
defaultFile = fopen("default.txt","r");
while(fscanf(defaultFile,"%[^\t]",defaultContent) == 1)
{
printf("%s\n", defaultContent);
}
fclose(defaultFile);
sleep(diff_time);
while(fscanf(contentFile,"%[^\t]",textContent) == 1)
{
printf("%s\n", textContent);
}
fclose(contentFile);
sleep(seconds);
}
else
{
if(diff_time < 0)
{
diff_time2 = diff_time + 86400;
defaultFile = fopen("default.txt","r");
while(fscanf(defaultFile,"%[^\t]",defaultContent) == 1)
{
printf("%s\n", defaultContent);
}
fclose(defaultFile);
sleep(diff_time2);
while(fscanf(contentFile,"%[^\t]",textContent) == 1)
{
printf("%s\n", textContent);
}
fclose(contentFile);
sleep(seconds);
}
else
{
if(diff_time == 0)
{
while(fscanf(contentFile,"%[^\t]",textContent) == 1)
{
printf("%s\n", textContent);
}
fclose(contentFile);
sleep(seconds);
}
}
}
}
}
else
{
sscanf(timeValue,"%d:%d",&hour,&min);
printf("\n< File does not exist >\n\n");
fclose(contentFile);
}
}
fclose(orderFile);
}
}
else
{
printf("\n< File does not exists, please create it again >\n\n");
fclose(orderFile);
}
printf("\n");
我所知道的是,在 sleep (秒)之后,我应该将其添加到used.txt中,但我不知道如何仅添加一次,如果还有其他更新该行。我虽然想使用“r+”,所以它会写在该行的顶部,但在我的程序中,我可以重命名文件,所以如果 file1.txt 将重命名为 file.txt,一个字符仍然会在那里,并且在结尾将是 ;11(应该是 1 或 0)。
知道如何在每次文件运行时正确更新的同时添加它吗?
<小时/>到目前为止我已经尝试过:
tempFile = fopen("temp.txt","w");
utilizadosFicheiro = fopen("utilizados.txt","r");
while(fscanf(utilizadosFicheiro," %49[^;];%d;%d;%d",ficheiroNome,&nApresentacao,&tempoAcumulado,&escalonamento) == 4)
{
fseek(tempFile, 0, SEEK_END);
size = ftell(tempFile);
rewind(tempFile);
if(size == 0)
{
fprintf(tempFile,"%s;%d;%d;%d\r\n",ficheiroNome,nApresentacao,tempoAcumulado,escalonamento);
}
else
{
while(fscanf(tempFile," %49[^;];%d;%d;%d",ficheiroNome2,&nApresentacao2,&tempoAcumulado2,&escalonamento2) == 4)
{
if(strcmp(ficheiroNome,ficheiroNome2) == 0)
{
// Edit the line with tempFile "r+"
}
else
{
// Keep line with tempFile "r"
fprintf(tempFile,"%s;%d;%d;%d\r\n",ficheiroNome,nApresentacao,tempoAcumulado,escalonamento);
}
}
}
}
ficheiroNome = fileName
nApresentacao = timesListedNumber
tempoAcumulado = totalSecondsListed
escalonamento = "time" (will either be 1 or 0)
最佳答案
用代码回答可能更容易:
#include <stdio.h>
#include <string.h>
struct used_entry_s {
char name[128];
int num_occurances;
int seconds_total;
int in_order_flag;
};
struct order_entry_s {
char name[128];
int seconds;
unsigned long long start;
};
/* first read from used.txt */
int read_entries(struct used_entry_s *entries) {
FILE *f = fopen("used.txt", "r");
struct used_entry_s entry;
int ne = 0;
if(!f) {
return 0;
}
while(fscanf(f, "%[^;];%d;%d;%d\n", entry.name, &entry.num_occurances,
&entry.seconds_total, &entry.in_order_flag) == 4) {
memcpy(&entries[ne], &entry, sizeof(entry));
ne++;
}
fclose(f);
return ne;
}
/* save in-memory used entries to file, overwriting its contents */
void save_entries(const struct used_entry_s *entries, int num_entries) {
int i;
FILE *f = fopen("used.txt", "w");
if(!f) {
return;
}
for(i = 0; i != num_entries; ++i) {
fprintf(f, "%s;%d;%d;%d\n", entries[i].name, entries[i].num_occurances,
entries[i].seconds_total, entries[i].in_order_flag);
}
fclose(f);
}
/* update in-memory entries with given file */
int update_entries(const char *filename, struct used_entry_s *entries,
int num_entries) {
int ne = num_entries;
FILE *f = fopen(filename, "r");
char time_str[128];
struct order_entry_s entry;
if(!f) {
return num_entries;
}
while(fscanf(f, "%[^;];%d;%[^\n]\n", entry.name, &entry.seconds, time_str) == 3) {
/* maybe convert time_str to time_t here, I'm too lazy for that */
int i;
for(i = 0; i != ne; ++i) {
if(strcmp(entries[i].name, entry.name) == 0) {
/* got match, update it */
entries[i].seconds_total += entry.seconds;
entries[i].num_occurances++;
break;
}
}
if(i == ne) {
/* no match found - add new one */
strcpy(entries[ne].name, entry.name);
entries[ne].num_occurances = 1;
entries[ne].seconds_total += entry.seconds;
entries[ne].in_order_flag = 1;
/* increase number of entries */
ne++;
}
}
fclose(f);
return ne;
}
int main(int argc, char **argv) {
/* maximum number of entries in used.txt */
#define MAX_USED_ENTRIES 128
struct used_entry_s used_entries[MAX_USED_ENTRIES];
int num_entries = read_entries(used_entries);
num_entries = update_entries("order.txt", used_entries, num_entries);
num_entries = update_entries("order.txt", used_entries, num_entries);
save_entries(used_entries, num_entries);
return 0;
}
它依赖 MAX_USED_ENTRIES 作为常量,并且从不检查溢出。如果需要的话可以改进,但这不是问题的主题。
关于c - 更新txt文件内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27766671/
我知道我要求太多,但也许你也可以帮助解决这个问题。 a.txt 包含单词,b.txt 包含字符串。 我想知道 b.txt 中有多少个字符串以 a.txt 中的单词结尾 例子:一个.txt apple
这个问题在这里已经有了答案: erge text files ordered by numerical filenames in Bash (3 个答案) 关闭 4 年前。 我有一个文件夹,其中包含
我在一个目录中有几个平面文件 (.txt)。所有这些文件的格式都是 *.txt.txt,所以我想将其重命名为 *.txt?有什么简单的方法可以一起重命名? 当我尝试 ren *.txt.txt *.t
这个问题在这里已经有了答案: How can I use a file in a command and redirect output to the same file without trunc
您是否有任何理由应该或不应该允许访问 javascript 或 css 文件?特别是常见的文件,如 jquery。 最佳答案 人们普遍认为,搜索引擎每天为给定站点分配一定数量的带宽或 URL。因此,一
Closed. This question is off-topic。它当前不接受答案。 想要改善这个问题吗? Update the question,所以它是用于堆栈溢出的on-topic。 已关闭
这是相同的代码。我面临的问题是,我无法在任何文件上写入任何内容。请帮忙解决这个问题 #include #include int main() { FILE *fe; FILE *fo;
我想要特定于域的 robots.txt,到目前为止这有效: RewriteRule ^robots\.txt$ robots/%{HTTP_HOST}.txt [L] 但我希望有一个后备方案,因此如果
我正在调试一些构建成功运行的 SQL 命令的代码。 然而,在查询结束时,查询结果似乎被写入了一个文本文件。 完整的查询如下 echo SELECT DATE,DATETABLE,DATE,APPDAT
这个问题已经有答案了: difference between grep Vs cat and grep (5 个回答) 已关闭 8 年前。 我看到一个例子,其中有人这样做: cat source.tx
我想将表中的数据从以 csv 格式存储的文本文件插入到 sql server 表中。为此,我正在使用批量插入语句。现在我需要在“From”子句中指定文件名。我不想在那里使用网络位置或本地位置。我想将我
假设我有一个测试文件夹 (test.domain.com) 并且我不希望搜索引擎在其中抓取,我是否需要在测试文件夹中有一个 robots.txt 或者我可以只放置一个 robots.txt在根目录中,
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 9年前关闭。 Improve this q
这个问题在这里已经有了答案: order of directives in robots.txt, do they overwrite each other or complement each ot
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 8年前关闭。 Improve this
已关闭。这个问题是 not about programming or software development 。目前不接受答案。 这个问题似乎不是关于 a specific programming
在过去的几年中,当我引用“名字”字段的文本框控件时,我一直使用 FirstNameTxt 命名约定。但是,我注意到大多数其他开发人员倾向于使用命名约定 txtFirstName 哪个是最好的约定?为什
我只想允许目录 /minsc 中的一个文件,但我想禁止该目录的其余部分。 现在 robots.txt 中是这样的: User-agent: * Crawl-delay: 10 # Directorie
我正在编写一个将 youtube.com 映射到另一个域的代理服务器(因此用户可以轻松地从德国等国家/地区访问 youtube,而无需审查搜索结果和视频)。 不幸的是,我的 robots.txt 中存
我没有编程技能,但有一项非常具体的任务:我必须将一个庞大的文本文件拆分成多个,并在特定的文本标记 (@) 处拆分它们。我决定尝试使用 Powershell 脚本来完成此任务。 到目前为止,这就是我想出
我是一名优秀的程序员,十分优秀!