- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
如何将这些值提取到数据库表中?
首先,我只是把它放在那里,而不是让你推断:我是一个 ROR 菜鸟。我正在设计一个填充数据库的应用程序——此时 (SQLite)——允许用户对这些值执行 crud,并以与原始文件相同的格式导出文件。这种格式是这样的,并在文档末尾重复。椭圆代表前一个和下一个音调。
...
[Tone27]
Atone = 707.3
Btone = 746.8
Btonelength = 3
Btonedebounce = 1
Description = Fire Department 1
mp3_Emails = email@address.com,email2@address.com,email3@address.com
amr_Emails = email2@textmessaging.com,email1@textmessaging.com
alert_command = c:\test.bat
post_email_command = c:\test2.bat
radio_frequency = 154.475
exclude_from = 13:25
exclude_to = 13:35
exclude_emails = email2@textmessaging.com,email2@address.com
...
现在的问题是,在 Rails 中,将这些值放入数据库表中的最简单/最合适的方法是什么?我知道我必须编写一个自定义解析器,但我对 ruby/rails 的了解还不足以有效地完成这项工作。
最佳答案
自定义解析器
需要逐行读取文件,读出要保存的属性。它可能看起来像这样:
file = File.new('example.txt', 'r')
while (line = file.gets)
if line.match(/^\W[a-zA-Z0-9]*\W/) # practice your regex at rubular.com
# create the object here
end
if line.match(/.*=.*/)
pieces = line.split('=')
key = pieces[0].strip
value = pieces[1].strip
# add this to the object here
end
end
我建议捕获每一行,修剪空白(如果有的话),然后在 = 符号上拆分,然后再次修剪。你有你的键/值对。
每个 [Tone##] 都是一个新对象,因此您需要将其规划到您的一个或多个循环中。
高级概述
首先,您应该使用迁移来设计数据库表并创建模型来支持这些表。
接下来您需要解析文本文件以创建具有您刚刚解析的属性和值的对象。这一步是您将遇到的最纯粹的 ruby (这里的 Rails 提供的帮助不多)。这将需要自定义解析器在文本文件中查找您想要提取的特定值。
一旦您使用从文本文件中解析出的属性和值创建了对象,您将希望将所有这些对象保存到数据库中。
我建议先构建一个示例或演示应用程序,然后再开始研究这个应用程序。有一些教程,您可以根据自己的经验水平在几个小时内启动并运行一个简单的应用程序。
这是对您需要完成的工作的高级概述,其中每个步骤很可能会导致更具体的 StackOverflow 问题。
关于ruby-on-rails - Rails 将 txt 文件导入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13606673/
我知道我要求太多,但也许你也可以帮助解决这个问题。 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 脚本来完成此任务。 到目前为止,这就是我想出
我是一名优秀的程序员,十分优秀!