python - Django 从查询集中删除重复项
全部标签 假设我有一个如下所示的数组:a=[cat,dog,cat,mouse,rat,dog,cat]我如何循环遍历它,并对重复项进行处理-例如说删除它们?换句话说,如果我执行了a.eachdo|i|,我将如何针对a[1]、a[2]、a[3]评估a[0]。..然后当我找到我想要的那个时,说a[2]在这种情况下有第一个副本,然后我将它插入堆栈或删除它或其他东西。我知道如何评估键和值...但是我如何在同一个数组中评估值?谢谢。 最佳答案 您可以创建一个散列来存储任何元素重复的次数。因此只遍历数组一次。h=Hash.new(0)['a','b',
我正在寻找类似CodeIgniter的东西:$this->db->last_query();(http://codeigniter.com/user_guide/database/helpers.html) 最佳答案 据我所知,访问查询列表并不容易。尽管如此,您还是可以轻松访问它们,创建一个super简单的记录器。如果您打开ActiveRecord::ConnectionAdapters::AbstractAdapter类,您将看到一个名为log的方法。在每个查询上调用此方法以记录语句。默认情况下,它使用Rails记录器记录所有语句
根据特定的键:值或方法返回的结果,删除对象数组中重复项的最快/单行方法是什么?例如,我有20个名称相同的XML元素节点,但它们具有不同的“文本”值,其中一些是重复的。我想通过说“ifelement.text==previous_element.text,删除它”来删除重复项。我如何用最短的代码在Ruby中做到这一点?我已经看到如何为简单的字符串/整数值执行此操作,但不是为对象执行此操作。 最佳答案 这是标准的散列方式。注意||=运算符的使用,这是一种更方便的(a||=b)方式来编写a=bunlessa.array.inject({}
我在Ruby中有以下数字数组(越高越好),我想对它们进行排序。换句话说,我想转换以下排序列表:[8952523618185]以下等级:[1224557]例如,获胜者获得第一名,并列第二名,依此类推。很明显,重要的一点是平局是可能的,然后这些平局必须跳过相应的行列。可能出现任意数量的并列(3人并列第二)。有没有一种优雅的方式来执行这种操作? 最佳答案 使用Enumerable#group_by:a=[89,52,52,36,18,18,5]rank=1a.group_by{|x|x}.map{|k,v|ret=[rank]*v.siz
我在这里想要实现的是假设我们有两个示例URL:url1="http://emy.dod.com/kaskaa/dkaiad/amaa//////////"url2="http://www.example.com/"如何提取精简的URL?url1="http://emy.dod.com/kaskaa/dkaiad/amaa"url2="http://http://www.example.com"Ruby中的URI.parse可以清除某些类型的格式错误的URL,但在这种情况下无效。如果我们使用正则表达式,那么/^(.*)\/$/会从url1中删除一个斜杠/并且对于url2。有人知道如何处理
我正在使用Paperclip-FFMEG将视频文件上传到我的开发环境(并最终在我的项目投入生产时上传到本地服务器)。上传视频时,文件名默认如下:/system/modelnames/paperclipnames/.../mynewfile.mp4?xxxxxxxxxx我相信问号后面的10位数字是时间戳。但是,我将用来播放视频的播放器不喜欢在文件附件后有任何内容-所以我想在将URL传递给播放器之前去掉问号和它后面的时间戳。我尝试使用以下Ruby(我认为)剥离函数:temp_variable=model.paperclipattribute.url(:blah).strip('?')[0]
我需要根据参数数据添加条件。@users=User.where('id',params[:id])unlessparams[:id].nil?@users=User.where('email',params[:email])unlessparams[:email].nil?@users=User.limit(10)但由于某些原因它不起作用。谢谢 最佳答案 您的每个语句都替换了@users变量,并且当ActiveRecord延迟计算每个语句时,永远不会调用前两个。如果您想维护三个独立的查询并以这种方式构建事物,您可以这样做:@user
我在AmazonS3中存储了很多图像,使用ruby库(http://amazon.rubyforge.org/)我不关心超过1周的照片,然后为了释放S3中的空间我必须删除这些照片。我知道有一种方法可以删除某个桶中的对象:S3Object.delete'photo-1.jpg','photos'有没有办法自动删除一周前的图片?如果它不存在,我将不得不编写一个守护进程来做到这一点:-(谢谢更新:现在可以了,查看Roberto的回答。 最佳答案 您可以使用AmazonS3对象过期策略AmazonS3-ObjectExpiration|AW
我正在遍历一系列URL并想清理它们。我有以下代码:#Parseurltoremovehttp,pathandcheckformato_url=URI.parse(node.attributes['href'])#Removewwwnew_url=o_url.host.gsub('www.','').strip我如何扩展它以删除某些URL中存在的子域? 最佳答案 我刚刚编写了一个名为Domainatrix的库来执行此操作。您可以在这里找到它:http://github.com/pauldix/domainatrixrequire'ru
我想使用最简单的方法从字符串中删除所有字符。例如从"a,sd331ds"到"asdds"我想这样做:"a,sd331ds".gsub(/\W/,"").gsub(/\d/,"")#=>"asdds"但是看起来有点别扭。也许可以将这些rexegs合并为一个? 最佳答案 "a,sd331ds".gsub(/(\W|\d)/,"") 关于ruby-删除所有非单词字符的简单方法,我们在StackOverflow上找到一个类似的问题: https://stackover