草庐IT

rand_seed

全部标签

ruby - 导轨 : seeding database data and date formats

我正在尝试使用db/seed.rb文件和rakedb:seed命令将一些数据播种到我正在开发的Rails3应用程序中。我播种的数据涉及一个名为Meeting的数据库表,该表具有三列:字符串标题、日期时间开始日期、日期时间结束日期。我尝试插入的日期时间采用“mm/dd/yyyyhh:mm”格式——例如。“01/02/200313:23”=2003年1月2日下午1:23。但是,DateTime.parse()始终会出现“无效日期”错误——因为它试图以“dd/mm/yyyy”格式解析日期。根据我的谷歌搜索,我被引导相信在解析DateTime对象时,编译器会查看传入的字符串并进行一些仓促的模式

ruby-on-rails - Heroku:如何将 seeds.rb 推送到现有的 Rails 应用程序?

我将所有应用程序的数据存储在本地的seeds.rb中。然而,在我将所有内容推送到Heroku之后,该应用程序运行良好,但没有任何数据。我不想再次重新输入海量数据,请问有没有人可以帮帮我? 最佳答案 如果将应用推送到heroku,则可以使用以下命令为数据库播种。herokurunrakedb:seed 关于ruby-on-rails-Heroku:如何将seeds.rb推送到现有的Rails应用程序?,我们在StackOverflow上找到一个类似的问题: ht

ruby-on-rails - 在 seeds.rb 中使用 Paperclip

假设我的seeds.rb文件中有以下条目:Image.create(:id=>52,:asset_file_name=>"somefile.jpg",:asset_file_size=>101668,:asset_content_type=>"image/jpeg",:product_id=>52)如果我播种它,它会尝试处理指定的图像,我会收到此错误:Nosuchfileordirectory-{filepath}etc...我的图像已经备份,所以我真的不需要创建它们;但我需要记录。我不能在我的模型中评论回形针指令;然后就可以了;但我想可能还有另一种解决方案。是否有另一种模式可以遵循以

ruby-on-rails - 如何使用 RSpec 测试 `rand()`?

我有一个方法可以做这样的事情:defsome_methodchance=rand(4)ifchance==1do#logichereelse#anotherlogichereendend当我用RSpec测试这个方法时,里面的rand(4)总是生成0。我不是在测试Rails的rand方法,我是在测试我的方法.测试我的方法的常见做法是什么? 最佳答案 我会考虑两种方法:方法1:在before:eachblock中使用srand(seed)中已知的种子值:before:eachdosrand(67809)end这适用于所有Ruby版本,并

ruby - Ruby 的 sort_by {rand} 是如何工作的?

我认为这是一个很棒的Ruby单行代码:someArray.sort_by{rand}它简洁明了,可读性强,而且行之有效-但我不太明白如何操作。这是我所知道的:rand计算为0到1之间的数字(例如0.783468632804653)rand在上面的代码中被重复计算,因为将它分配给x首先会破坏随机排序sort_by{0.783468632804653},或我试过的任何其他数字,对数组没有影响ruby-doc.org对我帮助不大inthiscase.谁能一步一步解释一下?更新我现在使用Ruby的时间更长了,我发现我在这里遗漏了一两个概念。关键是:rand是一种方法(定义在内核上);它生成一个

ruby-on-rails - 拆分 seeds.rb 文件

这个问题在这里已经有了答案:Splitseeds.rbintomultiplesections?(2个答案)关闭8年前。我的seeds.rb文件变得非常大。重构文件中数据的最佳方式是什么?我可以将数据放入各种文件中,并在seeds.rb文件中require吗?

ruby-on-rails - 附加到 rake db :seed in rails and running it without duplicating data

Rakedb:seed使用应用程序的默认数据库值填充您的数据库,对吗?那么如果您已经有一个种子并且需要添加到它(您添加一个需要种子的新功能)怎么办?根据我的经验,当我再次运行rakedb:seed时,它已经添加了现有内容,因此现有内容变成了两倍。我需要的是添加一些种子,当运行时,它应该只添加最新的种子,而忽略现有的种子。我该怎么做?(我通常采用的肮脏的、菜鸟的方式是截断我的整个数据库然后再次运行种子,但这在生产中不是很聪明,对吧?) 最佳答案 更简洁的方法是使用find_or_create_by,如下所示:User.find_or_

c - golang rand() 是否使用 libc rand()

我在golang和C中使用相同的种子,但得到不同的随机数我知道php使用libcrand(),golang怎么样?//golang:rand.Seed(12345);rand.Uint32();//C:srand(12345);rand(); 最佳答案 不,rand包根本不使用C标准库,您可以通过查看每个源文件来判断它不使用CGO。exp.go:import("math")normal.goimport("math")rand.goimport"sync"rng.go没有进口zipf.go:import"math"

go - rand.Prime(rand.Reader, 3072) 执行时间长

我以实现RSA为例。几周前,它似乎工作正常。然而,现在key的生成需要很长时间(>10秒)。我已将范围缩小到以下行:import"crypto/rand"p,_:=rand.Prime(rand.Reader,3072)为什么这会花费大量时间? 最佳答案 除了进行素性测试的计算成本外,根据crypto/rand文档中,这些数字来自“加密安全伪随机数生成器”。这种随机性来源mightbeslow,具体取决于您的环境。这可能就是为什么crypto/prime使用io.Reader的原因,这样我们就可以为它提供另一个随机源。e.g.:pa

go - 为什么每次运行程序时 math/rand 包中的 rand.Intn() 函数都会生成相同的随机数序列?

我使用rand.Intn(nint)函数交换slice内的元素,但每次运行该程序时,输出都是slice内相同的随机元素序列。我在这里缺少什么明显的东西? 最佳答案 来自documentationUsetheSeedfunctiontoinitializethedefaultSourceifdifferentbehaviorisrequiredforeachrun.IfSeedisnotcalled,thegeneratorbehavesasifseededbySeed(1).默认情况下,每次运行都会获得相同的种子。您可以使用当前时间