Rails + Populator + Faker

29 ноября 2008

Часто в процессе разработки сайта на Rails нужно быстро создать много данных, например для тестирования пажинатора.

Можно написать rake задачу, можно добавлять вручную. В любом случае тяжело гарантировать приближенность к реальности вводимых данных. Например, выдумывать 1000 электронных адресов, фамилий и т.д. это не шутка.

Чтобы сэкономить время рекомендую воспользоваться библиотекой populator.

Ставим:

  gem install populator 

Используем. Например, нам нужно добавить в базу 3000 записей о пользователях

  User.populate(3000) do |user|
    user.first_name = “Tony”
    user.last_name = “Stark”
  end

В целом неплохо. Но как, то не очень хорошо, что у нас в базе 3000 железных людей. Нам бы разнообразия.

Для этого есть еще одна чудная библиотечка faker. Ставим:

  gem install faker 

Теперь перепишем наш пример, добавив пару дополнительных полей и оформив в rake задачу, чтобы удобно было запускать, например в production:

  require ‘populator’
  require ‘faker’

  require ‘rake’
  require ‘rake/testtask’
  require ‘rake/rdoctask’

  require ‘rubygems’
  require(File.join(File.dirname(__FILE__), ‘../../config/environment.rb’))

  namespace :populate do
     desc “Add test data”
     task(:users) do
       User.populate(3000) do |user|
         user.first_name = Faker::Name.first_name # генерирует Имя
         user.last_name = Faker::Name.last_name   # Фамилию
         user.email = Faker::Internet.email       # мыло
         user.login = Faker::Internet.user_name   # логин
         user.phone = Faker::PhoneNumber.phone_number # номер телефона
         user.about = Faker::Lorem.paragraphs( 5 ) # О себе – 5 параграфов
       end
    end
  end

Теперь у нас в базе в любой конфигурации может быть 3000 пользователей с совершенно разными данными. Очень удобно. Сокращает время, и появляются дополнительные возможности тестирования.

Graphicoolus - сервис построения графиков

27 ноября 2008

Недавно был открыт простенький сервис построения графиков и диаграмм - Graphicoolus.

Сервис предоставляет возможность строить графики нескольких видов - собственно график, гистограмма, круговая диаграмма и пузырьковая диаграмма.

Создание осуществляется в несколько простых интуитивно понятных шагов, после выполнения которых получаем код для встраивания графика в страницу Вашего сайта.

И на последок пример графика созданного с помощью данного сервиса:

Кому интересно испытать сервис в работе кликаем сюда.

Строим графики и диаграммы с open flash chart

22 октября 2008

Очень часто возникает необходимость каким-либо способом визуализировать данные, например в виде графиков и диаграмм. В такой ситуации на помощь может прийти плагинчег - open flash chart.

Ну и для начала установим его:

ruby script/plugin install http://svn.pullmonkey.com/plugins/trunk/open_flash_chart/

После нужно скопировать файлик open_flash_chart.swf в path/to/your/app/public/ и файлик swfobject.js в  path/to/your/app/public/javascripts.

Данный плагин сводит до минимума роботу программиста, поэтому не буду изощряться примерами и просто оставлю ссылку, где все и так видно. Кому интересно жмем сюда

Perl жив

5 октября 2008

Некоторое время назад мне приходилось разрабатывать и поддерживать веб ориентированую систему на perl. Система должна была работать с БД (MySQL),  кроме того были несколько страниц где использовались AJAX вызовы.

В целом тогда был страшный бум php и перл особо не был популярным. Как мне даже показалось, дни перла в веб разработке сочтены.

Как я ошибался (к счастью). На  perl разрабатывают. Мало того, существует даже полноценный MVC веб-фреймворк для разработки на perl.

Имя сему чуду Catalyst.

Достать его можно из архива cpan (как и все что относится к разработке на perl).

Работает он на всех популярных веб-серверах и операционных системах. А на Apache он работает через mod_perl что не может не радовать.

Из несомненных полезностей - наличие системы плагинов, что позволит Фреймворку расти и набираться функциональности.

Самое интересное то, что Интернет просто вспыхнул как-то новостями об Catalyst. Что не может не радовать меня как perl разработчика (хоть и бывшего). Обязательно наваяю что то на нем.

На последок неплохое видео по использованию этого без сомнения замечательного фреймворка.

Cheat sheets

3 октября 2008

В последнее время в интернете появляется все больше разного рода шпаргалок, так называемых Cheat Sheet.

Мы собрали парочку ссылок на самые интересные (с нашей точки зрения). Итак:

  • Вот на этом сайте часто выкладывают довольно толковые.
    • Subversion Cheat Sheet pdf, png;
    • Regular Expressions Cheat Sheet pdf, png;
    • CSS Cheat Sheet pdf, png;
    • HTML Cheat Sheet pdf, png.
  • Кроме того есть еще и такой сайт где собраны все самые интересные шпаргалки в одном месте. Приведу парочку прямых ссылок:

В целом шпаргалки можно применять в качестве красивых и функциональных обоев на стену.

composite primary keys

2 октября 2008

Дело в том, что Ruby on Rails не поддерживает составные первичные ключи. Но эту проблему можно решить с помощью гемки composite_primary_keys.

И ставим gem:

  gem install composite_primary_keys

Модель с составным первичным ключем будет выглядеть следующим образом:

  require 'composite_primary_keys'

  class Probability < ActiveRecord::Base
    set_primary_keys :row, :col
  end

И напоследок несколько примеров использования:

  Probability.primary_key # => [:row, :col]
  Probability.primary_key.to_s # => "row,col"
  Probability.find(1,1) # => <Probability row: 1, col: 1, val: 17>
  Probability.find [1,1],[1,2] # => [<Probability row: 1, col: 1, val: 17>, <Probability row: 1, col: 2, val: 19>]
  Probability.find(:first).to_param # => "1,1"

ActiveRecordBase Without Table

1 октября 2008

Бываю случаи, когда необходимо создать модель ActiveRecord но без таблицы в БД. Например, чтобы воспользоваться валидаторами Rails.
Для этого есть замечательный плагин ActiveRecordBaseWithoutTable.
Ставим:

    ruby script/plugin install http://svn.viney.net.nz/things/branches/active_record_base_without_table

Используем в модели:

  class Contact < ActiveRecord::BaseWithoutTable
    column :name, :string
    column :email_address, :string
    column :message, :text
    validates_presence_of :name, :email_address, :string
   end

И все.

Но будьте осторожны некоторые валидаторы лезут в БД чтобы проверить это все. Для таких нужно будет перегружать методы ActiveRecord.

В целом код плагина очень простой. И его можно улучшать на предмет дополнительных возможностей.

Вот и весь плагин.

module ActiveRecord
  class BaseWithoutTable < Base
    self.abstract_class = true

    class << self
      def columns()
        @columns ||= []
      end

      def column(name, sql_type = nil, default = nil, null = true)
        columns << ActiveRecord::ConnectionAdapters::Column.new(name.to_s, default, sql_type.to_s, null)
        reset_column_information
      end

      # Do not reset @columns
      def reset_column_information
		generated_methods.each { |name| undef_method(name) }
 		@column_names = @columns_hash = @content_columns = @dynamic_methods_hash = @read_methods = nil
      end
    end
  end
end

Еще будет.

ferret - Полнотекстовый поиск в вашем сайте

27 сентября 2008

Создание поиска по сайту задача частая и тривиальная. В Rails в основном осуществляется поиск по информации, которая хранится в моделях. Для этого в ActiveRecord есть метод find. Существует масса примеров как можно осуществлять поиск при помощи этого метода. Но у него есть существенный недостаток. На самом деле это обертка вокруг SELECT запроса, поэтому если ваш поиск сложнее чем просто выборка этот метод вам не подойдет. Кроме того, простой find имеет существенный недостаток - скорость. Если Вы используете MySQL, можете переключиться на MySQL full text search - лично я не пробовал но блоги пишут, что сильно ускоряет. Решение плохое так как привяжет вас к СУБД, что не есть очень хорошо.

Для организации эффективного и самое главное быстрого поиска применяются так называемые индексные сервера. Жависты имеют в своем арсенале Lucene - неплохой движок для полнотекстового поиска. Лопатит миллионы строк и возвращает очень даже приемлемые результаты.

Но наряду с позитивом есть и негатив. Lucene - написан на жаве и для того чтобы его использовать нужно поднимать на сервере жаву, Tomcat и т.д. В принципе ничего сложного, тем более есть мануалы.

Но есть альтернатива! ferret - библиотека для полнотекстового поиска написана на Ruby.

Инсталлируем

 gem install ferret

Правда просто? ИМХО gem - гениальная вещь.

Но, есть одно маленькое НО. Для успешной установки ferret на Win32 необходимо иметь в наличии компилятор С/С++. Я воспользовался для этого VC++ 6.0. Для того чтобы все прошло гладко, необходимо настроить пути компиляции( переменные окружения LIB, INCLUDE, PATH).

Используем совместно с ActiveRecord в RubyOnRails

Для того чтобы все было гладко есть плагин - Acts as Ferret. ( Правда этот плагин доступен также и как gem ).

Ставим плагин

script/plugin install svn://projects.jkraemer.net/acts_as_ferret/tags/stable/acts_as_ferret

Используем в моделях

Вписываем в модель такой код:

class Foo < ActiveRecord::Base
   acts_as_ferret
end

Тоже не сложно. После такой записи у вас будет доступен следующий синтаксис:

 Foo.find_with_ferret("запрос")

Кроме того ferret создаст директорию index в Вашем проекте, в которой создаст также поддиректории конфигураций запуска (test, development, production). В этих директориях ferret и будет сохранять индексы. Для каждой модели будет создано свою поддиректорию.

Индексом можно управлять. По умолчанию добавление/удаление данных в модели провоцирует обновление индекса. Кроме того Вы сами можете настраивать, что отображать в поиске а что нет. Для постраничного вывода также существует ряд параметров поиска (limit, page).

Это конечно только вершина айсберга использования ferret, завесу понимания приоткроет чтение документации.

Вот и все. Будут вопросы - пишите.

Новый дизайн

9 сентября 2008

Уух заработались и даже забыли всем сообщить о том, что на сайте ж новый дизайн. Быстро всем смотреть и фидбечить сюда. Все коменты велком.

CSV with Ruby

22 августа 2008

Если стоит задача работы с csv(Comma Separated Values) файлами на помошь может прийти замечательная гемка fastercsv. Ставится она, как и все, очень просто:

gem install fastercsv

Ну и конечно небольшой примерчег кода где открывается csv файл, парситься и выводиться его содержимое в консоль:

require ‘fastercsv’

FasterCSV.parse( File.open( “example.csv” ) ) do |row|

row.each {|cell| puts cell}

end

Вот и все :)

Блог работает на WordPress.
Подписка RSS: все записи, комментарии.