c++ - 从 C++ 中的 txt 文件中提取条目的代码优化问题
问题描述
我在下面开发了一些代码,这些代码将从列表中提取条目并构建一系列条目以供以后使用。我使用的列表和代码如下。
使用 ifstream 函数,我从列表中抓取字符,每次代码到达下一行字符\n
时,代码将编译文本,构建字符串并移至下一行。
这对于从 txt 文件中提取是否有效,它有效但感觉效率低下。
文本文件列表
name
title
year
manufacturer
developer
genre
cloneOf
players
ctrltype
buttons
joyways
rating
score
我正在尝试优化的当前代码
#include "pch.h"
#include <iostream>
#include <string>
#include <fstream>
std::string sql;
std::string Entryname;
std::string Entryappends;
int main()
{
std::ifstream MetaEntries ("c:\\CodeRepo/List.txt", std::ifstream::in);
sql.append("CREATE TABLE IF NOT EXISTS Meta(");
sql.append("collectionName TEXT KEY,");
char c = MetaEntries.get();
while (MetaEntries.good()) {
if (c == '\n') {
Entryappends = std::string(" TEXT NOT NULL DEFAULT '', ");
sql.append(Entryname + Entryappends);
Entryname.clear();
}
Entryname += c;
c = MetaEntries.get();
// std::cout << Entryname;
}
MetaEntries.close();
Entryappends = std::string(" TEXT NOT NULL DEFAULT '';");
sql.append(Entryname + Entryappends);
sql.append("CREATE UNIQUE INDEX IF NOT EXISTS MetaUniqueId ON Meta(collectionName, name);");
std::cout << sql;
return 0;
}
输出:它几乎完全按照预期工作。
CREATE TABLE IF NOT EXISTS Meta(collectionName TEXT KEY,name TEXT NOT NULL DEFAULT '',
title TEXT NOT NULL DEFAULT '',
year TEXT NOT NULL DEFAULT '',
manufacturer TEXT NOT NULL DEFAULT '',
developer TEXT NOT NULL DEFAULT '',
genre TEXT NOT NULL DEFAULT '',
cloneOf TEXT NOT NULL DEFAULT '',
players TEXT NOT NULL DEFAULT '',
ctrltype TEXT NOT NULL DEFAULT '',
buttons TEXT NOT NULL DEFAULT '',
joyways TEXT NOT NULL DEFAULT '',
rating TEXT NOT NULL DEFAULT '',
score TEXT NOT NULL DEFAULT '';CREATE UNIQUE INDEX IF NOT EXISTS MetaUniqueId ON Meta(collectionName, name);
解决方案
推荐阅读
- python - Python:求大数组的乘积时,如何最好地减少浮点错误?
- javascript - Javascript - onclick 函数更改布尔值并更改 attr 可见性
- python - 带有 word2vec 的文本多标签
- cmake - 如何在 CMake 中不修复 OPENSSL 版本
- ios - 如何实现 iMovie 修剪视图?
- python - 为 AWS Lambda 打包 Python Pipenv 项目
- r - 使用引用在 tidyverse 中编程过滤器
- android - Sqlite 重启应用后抛出“Unknown Tokenizer”异常
- javascript - 如何初始化多个firebase项目
- python - 递归地将(标签,列表)对转换为字典