1.try 永远不会抛出异常 在 没有的时候 返回 nil
province_id = Province.find_by_name(prov).try(:id)
2.find(:first, :condotions) 方法 不言而与mobile_info = MobileInfo.find(:first, :conditions => ["mobile_num = ? ", mobile_num.to_i])
3.find(:all, :select, :conditions)support_amount_a = ProvinceMerchantChangeValue.find(:all, :select => "DISTINCT change_value_id",
:conditions => ["status = 1 and merchant_id = ? and province_id =? and channel_id in (select id from channels where status = 1)",
merchant_id, province_id]).map { |cv| cv.change_value_id }.compact
support_amount_s = ChangeValue.find(:all,:select => "price" ,:conditions => ["id in (?)", support_amount_a]) \
.map { |cv| cv.try(:price).to_i }.compact
4.发送post请求 可以在shell中执行
curl -d "channel=中信异度支付&action_type=娱人节-手机充值&user_indicate=13911731997&original_amount=10000" http://xx.xxx.xxx:3000/search.json
curl -d "channel=中信异度支付&action_type=娱人节-手机充值&user_indicate=13911731997&original_amount=10000"
http://xx.xxx.xxx:3000/search.json
|
5.Ruby 中纯数据结构 ( Struct 与 OpenStruct )
讲一下它俩之间的区别:
Struct需要开头明确声明字段; 而OpenStruct人如其名,
随时可以添加属性
Struct性能优秀; 而OpenStruct差点,
具体的性能差距可看这里:http://stackoverflow.com/questions/1177594/ruby-struct-vs-openstruct
Struct是 Ruby 解释器内置, 用 C 实现;OpenStruct是
Ruby 标准库, Ruby 实现
API 不同:Struct API与OpenStruct
6. MIme::Type.register
Mime::Type.register "application/json", :ejson
config/initializers/mime_types.rb7.config/initializers/secure_problem_solved.rbActiveSupport::CoreExtensions::Hash::Conversions::XML_PARSING.delete('symbol')
ActiveSupport::CoreExtensions::Hash::Conversions::XML_PARSING.delete('yaml')
8.config/initializers/new_rails_default.rbif defined?(ActiveRecord)
# Include Active Record class name as root for JSON serialized output.
ActiveRecord::Base.include_root_in_json = true
# Store the full class name (including module namespace) in STI type column.
ActiveRecord::Base.store_full_sti_class = true
end
ActionController::Routing.generate_best_match = false
# Use ISO 8601 format for JSON serialized times and dates.
ActiveSupport.use_standard_json_time_format = true
# Don't escape HTML entities in JSON, leave that for the #json_escape helper.
# if you're including raw json in an HTML page.
ActiveSupport.escape_html_entities_in_json = false
9.MemCacheStore 缓存@_cache = ActiveSupport::Cache::MemCacheStore.new(
CONFIG['host'], { :namespace => "#{CONFIG['namespace']}::#{@name}" }
)
localhost::callback_lock
@_cache.write(pay_channel.channel_id,'true’)
v = @_cache.read(pay_channel.channel_id)
if v.nil? || v != 'true'
return false
else
return true
end
end
10.联合索引gem 'composite_primary_keys', '6.0.1'https://github.com/momoplan10.Hash assert_valid_keys 白名单11.puma -C puma_service_qa.rb12.pow13. Timestart_time = start_time.to_s.to_datetime.at_beginning_of_day
end_time = end_time.to_s.to_datetime.end_of_day
14.merchant.instance_of? MplusMerchantm_order[:merchant_id] = (merchant.instance_of? MplusMerchant) ? merchant.id : merchant
15.will_paginate rails安装之后需要修改config/environment.rb文件在文件的最后添加:require 'will_paginate'
修改controller文件中的index方法:
# @products = Product.find(:all)
@products = Product.paginate :page => params[:page],
:per_page => 2
.pagination
= will_paginate @mplus_orders, :class => 'digg_pagination'
最好有个include
16. # Excel Generatorgem 'spreadsheet', '~> 0.7.3' PROVINCE = %w{ 安徽 北京 福建 甘肃 广东 广西 贵州 海南 河北 河南 黑龙江 湖北
湖南 吉林 江苏 江西 辽宁 内蒙古 宁夏 青海 山东 山西 陕西 上海
四川 天津 西藏 新疆 云南 浙江 重庆 }
MONTH = 1.upto(12).to_a
def self.total_to_xls(year = '2012', opts = {})
book = Spreadsheet::Workbook.new
sheet1 = book.create_worksheet
months = MONTH
months = opts[:month].to_s.split(/,/) if opts[:month]
fixed_row = months.collect{ |m| m.to_s + '月' }.insert(0, '')
sheet1.row(0).concat(fixed_row)
row1 = ['']
(months.size - 1).times { row1 << ['用户数', '金额', '订单数'] }
sheet1.row(1).concat(row1.flatten!)
row = 2
sheet1.row(row).insert(0, '全国')
months.each_with_index do |m, i|
sheet1.row(row).insert(i*3 + 1, self.monthly_users_count(m))
sheet1.row(row).insert(i*3 + 2, self.monthly_amount(m))
sheet1.row(row).insert(i*3 + 3, self.monthly_orders_count(m))
end
PROVINCE.each do |province|
row += 1
sheet1.row(row).insert(0, province)
months.each_with_index do |m, i|
sheet1.row(row).insert(i*3 + 1, self.monthly_users_count_by_province(m, province))
sheet1.row(row).insert(i*3 + 2, self.monthly_amount_by_province(m, province))
sheet1.row(row).insert(i*3 + 3, self.monthly_orders_count_by_province(m, province))
end
end
path = "tmp/phone_recharge.xls"
book.write path
path
end
17. inject({})selected_conditions = base_conditions.inject({}) do |hash, data|
hash[data.first] = data.last unless data.last.blank?
hash
end
18.time_str.instance_of?return time_str if time_str.instance_of? Time
19.Person.instance_evalPerson.instance_eval do
def species
"Homo Sapien"
end
end
20.class_eval
class Foo
end
metaclass = (class << Foo; self; end)
metaclass.class_eval do
def species
"Homo Sapien"
end
end
end
21.
Ruby中 respond_to? 和 send 的用法
http://galeki.is-programmer.com/posts/183.html
因为obj对象没法响应talk这个消息,如果使用 respond_to? 这个方法,就可以实现判断对象能否响应给定的消息了
obj =Object.new
ifobj.respond_to?("talk")
obj.talk
else
puts"Sorry,
object can't talk!"
end
request =gets.chomp
ifbook.respond_to?(request)
putsbook.send(request)
else
puts"Input
error"
end
22.
method_missing,一个 Ruby 程序员的梦中情人
def method_missing(method, *args)
if method.to_s =~ /(.*)_with_cent$/
attr_name = $1
if self.respond_to?(attr_name)
'%.2f' % (self.send(attr_name).to_f / 100.00)
else
super
end
end
end
http://ruby-china.org/topics/343423.chompchomp方法是移除字符串尾部的分离符,例如\n,\r等...而gets默认的分离符是\n24. hash.each_pair{|k,v|} & send() if bank_order.present?
data_hash.each_pair { |k, v| bank_order.send("#{k}=", v) }
else
bank_order = BankOrder.new data_hash
end
25.config.middleware 通过 rake -T 可以查看, 在config/ - 去除不必的 middleware26.1.day.ago.strftime('%Y%m%d’)
分享到:
相关推荐
### Ruby的25个编程细节(技巧、实用代码段) #### 1. 使用 `try` 方法处理潜在的异常 在Ruby中,`try` 方法是一个非常有用的功能,它允许我们安全地访问对象的方法或属性,即使该对象为 `nil` 也不会抛出异常。...
通过以上对Ruby编程语言的详细介绍,我们不仅了解了其基础知识,还探索了一些高级概念和技术。无论是对于初学者还是有经验的开发者来说,“Ruby编程Ruby Programming”这本书都能够提供宝贵的指导和资源。希望这些...
在压缩包子文件的文件名称列表中,“eps-master”可能是某个项目或库的名称,但具体细节不足,无法提供更深入的解释。通常,"master"分支在版本控制中代表项目的主分支,可能包含了所有核心代码和资源。 总的来说,...
- **默认线程安全性**:Ruby标准库中的一些类和方法默认是线程安全的,但并非所有都是。 - **使用互斥锁保护数据**:互斥锁(Mutex)是一种常用的同步机制,用于确保一次只有一个线程访问共享资源。通过在关键操作...
Ruby是一种面向对象的脚本语言,以其简洁、优雅的语法和强大的编程能力而闻名。...在阅读这些文档时,可以查找特定方法的用法、学习新的类和模块,以及查阅语言的语法细节,从而更好地驾驭Ruby 2.0。
一旦设置好,你就可以像操作普通属性一样处理翻译,Ruby-Mobility会自动处理背后的所有细节。 Ruby-Mobility还提供了查询辅助方法,使得在数据库查询中加入语言条件变得简单。比如,你可以很容易地获取特定语言的...
它简化了Cassandra API的使用,让Ruby程序员无需深入了解底层细节就能进行数据库操作。 在压缩包内的文件“datastax-ruby-driver-91d2607”可能是这个驱动的源代码或者特定版本的打包文件。DataStax是一家专注于...
《Programming Ruby》被誉为是最好的Ruby编程书籍之一,它不仅详尽地介绍了Ruby语言的基础知识,还深入探讨了Ruby的核心概念和技术细节。这本书由David Thomas、Andy Hunt、Thomas A.EW Matthews和David Heinemeier ...
通过Tilt,开发者可以方便地使用这些模板引擎,而无需关心它们的具体实现细节。 Tilt库的核心是一个注册表,它包含了对多种模板引擎的支持。当你创建一个新的模板实例时,Tilt会根据文件扩展名自动选择合适的引擎。...
- **Ruby Under a Microscope**:本书旨在通过显微镜般的视角来深入分析Ruby编程语言的内部实现细节。 #### 描述解读 - **Ruby编译器实现解析**:这本书详细介绍了Ruby编译器的工作原理以及其实现细节,帮助读者...
本书首先通过一个快速指南带您熟悉这门语言,然后彻底解释它的细节,包括: Ruby程序的词法和句法结构 数据类型和对象 表达式和操作符 语句和控制结构 Method、proc、lambda和closure 类和模块 反射和...
通过查看这个文件,你可以深入了解Yard的实现细节,包括源代码、测试、示例等,这对于深入学习和贡献Yard项目非常有帮助。 总结来说,Ruby-Yard是一款不可或缺的Ruby开发工具,它通过自动化文档生成和强大的定制...
至于Ruby教程中文版,它将覆盖更多细节,包括类和模块、异常处理、文件操作、网络编程、Gem(Ruby的包管理系统)的使用等。通过阅读和实践教程中的例子,你可以逐步提升对Ruby的理解和应用能力。 总的来说,Ruby是...
Ruby-Squid库提供了丰富的API,可以让你控制图表的每个细节。例如,你可以设置轴的标签、网格线、图例的位置和颜色,甚至添加自定义的注释文本。此外,Squid还支持组合图表,允许在一个PDF页面上绘制多种类型的图表...
此外,它的灵活性体现在可以自定义各种图表类型,包括折线图、柱状图、饼图、散点图等多种图表,并能自由配置颜色、数据系列、轴标签、图例、工具提示等各种细节。 在Ruby on Rails环境中,Ruby-LazyHighCharts可以...
一旦客户端建立,你可以像调用Ruby方法一样调用SOAP服务的函数,Savon会处理所有细节: ```ruby response = client.call(:some_method, message: {param1: "value1", param2: "value2"}) ``` Savon还支持一些高级...
虽然短短的时间无法让你精通所有细节,但足以激发你进一步探索Ruby世界的兴趣。从基本语法到面向对象编程,Ruby提供了一种直观且富有表达力的方式来编写代码。随着学习的深入,你会发现Ruby在许多领域都有广泛的应用...
这个库使得在Ruby环境中进行Web服务交互变得极其简单,是开发者进行API测试和集成时的常用工具。RESTClient提供了丰富的功能,可以方便地发送GET、POST、PUT、DELETE等各种HTTP请求,并能处理响应的各种数据格式,如...
本课程将涵盖Ruby on Rails的核心概念和技术细节,具体内容包括: - **周一**:安装Ruby on Rails环境、了解其背后的哲学思想以及MVC架构。 - **周二**:创建第一个应用程序,学习如何处理文件、生成器和脚本。 - *...
通过DBI,开发者可以无需关注底层数据库的细节,而专注于编写与数据库交互的业务逻辑。Ruby/DBI 支持的数据库驱动包括 MySQL、Oracle、PostgreSQL 和 SQLite 等。 1. **Ruby 连接 MySQL**: - 使用 `mysql2` GEM,...