我有一些数据(实际上是 MARC 记录),我正在尝试使用 go(版本 1.9.2)创建,但我不知道如何将定界字符写入输出文件。
下面的代码片段是我能想到的最接近的示例。第一项用适当的终止符写入,但之后没有其他内容。
在 go 中编写这些类型的终止字符的最佳/正确方法是什么?
const fieldTerminator = 0x1e
func main() {
data := []string{"item one", "item two", "item tre"}
writer, err := os.Create("x.out")
if err != nil {
log.Fatalf("Could not open file: %q\n", err)
}
defer writer.Close() // per biosckon
ft := make([]byte, 2)
binary.LittleEndian.PutUint16(ft, uint16(fieldTerminator))
for _, d := range data {
// this just proves to me that the loop is working
//os.Stderr.WriteString(fmt.Sprintf("d is %q\n", d))
fmt.Fprintf(os.Stderr, "d is %q\n", d) // per Andy Schweig
_, err := writer.Write([]byte(d))
if err != nil {
log.Fatalf("%q\n", err)
}
// This prints the correct character at the end of the first item
// and nothing after that (items 2 and 3 not printed, no errors):
_, err = writer.Write(ft)
if err != nil {
log.Fatalf("%q\n", err)
}
}
}
编辑:更新代码片段以解决 Andy Schweig 和 biosckon 的建议。
最佳答案
问题在于如何使用 binary.LittleEndian.PutUint16。
需要的是字段终止符的单个字节。 PutUint16 的结果是两个字节,终止符字节和一个空字节(如果 ft 定义为一个字节并且没有 PutUint8,PutUint16 将不起作用)。所以解决方法是在删除空字节之后截断 ft。
按要求进行以下工作:
const fieldTerminator = 0x1e
func main() {
data := []string{"item one", "item two", "item tre"}
writer, err := os.Create("x.out")
if err != nil {
log.Fatalf("Could not open file: %q\n", err)
}
defer writer.Close()
ft := make([]byte, 2)
binary.LittleEndian.PutUint16(ft, uint16(fieldTerminator))
ft = ft[:1] // Truncate ft to a single byte
for _, d := range data {
_, err := writer.Write([]byte(d))
if err != nil {
log.Fatalf("%q\n", err)
}
_, err = writer.Write(ft)
if err != nil {
log.Fatalf("%q\n", err)
}
}
}
关于go - 第一次写入后写入终止符(即 ox1e)失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48001130/
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
在选择我想要运行操作的频率时,唯一的选项是“每天”、“每小时”和“每10分钟”。谢谢!我想为我的Rails3.1应用程序运行调度程序。 最佳答案 这不是一个优雅的解决方案,但您可以安排它每天运行,并在实际开始工作之前检查日期是否为当月的第一天。 关于ruby-如何每月在Heroku运行一次Scheduler插件?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8692687/
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r
我正在尝试在Rails上安装ruby,到目前为止一切都已安装,但是当我尝试使用rakedb:create创建数据库时,我收到一个奇怪的错误:dyld:lazysymbolbindingfailed:Symbolnotfound:_mysql_get_client_infoReferencedfrom:/Library/Ruby/Gems/1.8/gems/mysql2-0.3.11/lib/mysql2/mysql2.bundleExpectedin:flatnamespacedyld:Symbolnotfound:_mysql_get_client_infoReferencedf
我想知道Ruby用来在命令行打印这些东西的输出流:irb(main):001:0>a="test"=>"test"irb(main):002:0>putsatest=>nilirb(main):003:0>a=>"test"$stdout是否用于irb(main):002:0>和irb(main):003:0>?而且,在这两次调用之间,$stdout的值是否有任何变化?另外,有人能告诉我打印/写入这些内容的Ruby源代码吗? 最佳答案 是的。而且很容易向自己测试/证明。在命令行试试这个:ruby-e'puts"foo"'>test.
我需要一个非常简单的字符串验证器来显示第一个符号与所需格式不对应的位置。我想使用正则表达式,但在这种情况下,我必须找到与表达式相对应的字符串停止的位置,但我找不到可以做到这一点的方法。(这一定是一种相当简单的方法……也许没有?)例如,如果我有正则表达式:/^Q+E+R+$/带字符串:"QQQQEEE2ER"期望的结果应该是7 最佳答案 一个想法:你可以做的是标记你的模式并用可选的嵌套捕获组编写它:^(Q+(E+(R+($)?)?)?)?然后你只需要计算你获得的捕获组的数量就可以知道正则表达式引擎在模式中停止的位置,你可以确定匹配结束
我写了一个非常简单的rake任务来尝试找到这个问题的根源。namespace:foodotaskbar::environmentdoputs'RUNNING'endend当在控制台中执行rakefoo:bar时,输出为:RUNNINGRUNNING当我执行任何rake任务时会发生这种情况。有没有人遇到过这样的事情?编辑上面的rake任务就是写在那个.rake文件中的所有内容。这是当前正在使用的Rakefile。requireFile.expand_path('../config/application',__FILE__)OurApp::Application.load_tasks这里
我正在尝试在配备ARMv7处理器的SynologyDS215j上安装ruby2.2.4或2.3.0。我用了optware-ng安装gcc、make、openssl、openssl-dev和zlib。我根据README中的说明安装了rbenv(版本1.0.0-19-g29b4da7)和ruby-build插件。.这些是随optware-ng安装的软件包及其版本binutils-2.25.1-1gcc-5.3.0-6gconv-modules-2.21-3glibc-opt-2.21-4libc-dev-2.21-1libgmp-6.0.0a-1libmpc-1.0.2-1libm
-if!request.path_info.include?'A'%{:id=>'A'}"Text"-else"Text"“文本”写了两次。我怎样才能只写一次并同时检查path_info是否包含“A”? 最佳答案 有两种方法可以做到这一点。使用部分,或使用content_forblock:如果“文本”较长,或者是一个重要的子树,您可以将其提取到一个部分。这会使您的代码变干一点。在给出的示例中,这似乎有点矫枉过正。在这种情况下更好的方法是使用content_forblock,如下所示:-if!request.path_info.inc