понедельник, 12 марта 2012 г.

Вставка текущего курса валют USD/UAH в ячейку таблицы google docs

Google Docs Spreadsheets очень удобный онлайн инструмент для ведения бухгалтерии. Допустим, что такая бухгалтерия ведеться в долларах США, но в конечном итоге надо получить все суммы в гривнах, учитывая текущий курс валют.

Как выход - в ячейку вбить текущий курс и отталкиватся от него. Минус такого подхода состоит в том, что постоянно придется корректировать этот самый текущий курс (как минимум раз в день) .

Есть удобные онлайн сервисы, которые постоянно показывают курсы валют. Почему бы и нам их не использовать в своей таблице?

На самом деле, тут все решабельно. В качестве такого онлайн сервиса, будет использовать ся Yahoo Finance. Страница, которая предоставляет нужный тип информации (USD в UAH) будет такая: http://finance.yahoo.com/q?s=USDUAH=X.

Остается только выбрать нужное значение со страницы и использовать для себя:

=VALUE(SUBSTITUTE((SUBSTITUTE(INDEX(ImportHTML("http://finance.yahoo.com/q?s=USDUAH=X";"table";1); 1;2);"*";""));".";","))


Вставим такую формулу в нужную ячейку таблицы - и вся задача.

Теперь немного детальнее пройдемся  по формуле:

VALUE - конвертирует текст в чисельное значение

SUBSTITUTE - функция, кторая заменяет одно значение в строке на другое. В нашем примере, мы сначала заменяем * на пустое значение (так как резуьтат выгребается в виде *7.92*), после чего, заменим точку на запятую - так как разделитель дробной части у меня запятая.

INDEX - получаем элемент массива (ячейку таблицы со значением курса валют)

ImportHTML - по заданому URL выгребаем контент, ищем в нем 1 таблицу.

jQuery. Быстрый итератор quickEach

Если вам нужно часто работать с итераторами each в jQuery, и вам приходиться часто внутри него пользоваться $(this), то есть смысл немного оптимизировать код.

Пример: необходимо перебрать список li и что-то сделать с каждым элементом списка
var list = $("ul li");
list.each(function() {
 var el = $(this); // получаем объект jQuery из объекта DOM
 el.....  // Какое-то действие с объектом
});

Следует помнить, что всегда нужно использовать групповые функции над списками, перебирать по одному не оптимально. Но представим себе, что задача стоит так, что без перебора списка поэлементно ее нельзя решить. Тогда узким местом такого алгоритма будет операция получения jQuery объекта на основе контекста this. В методе $.each(), this не является объектом, jQuery - он указывает на текущий элемент DOM. Потому, его надо привести к объекту jQuery, а это есть ресурсоемкая операция.

Можно использовать оптимизированный итератор $.quickEach() описанный ниже, который сразу возвращает в this объект jQuery и его не нужно получать в цикле для каждого элемента DOM которые мы итерируем.

/**
 *  jQuery quick Each
 *
 *  Example:
 *  a.quickEach(function() {
 *      this; // jQuery object
 *  });
 */
jQuery.fn.quickEach = (function() {
    var jq = jQuery([1]);
    return function(c) {
        var i = -1, el, len = this.length;
        try {
            while (++i < len && (el = jq[0] = this[i]) && c.call(jq, i, el) !== false);
        } catch (e) {
            delete jq[0];
            throw e;
        }
        delete jq[0];
        return this;
    };
 }());
Пример использования:
// Стандартный итератор
list.each(function() {
 var el = $(this);
});

// Оптимизированный итератор:
list.quickEach(function() {
 var el = this; // jQuery object
});
Оригинальная статья находиться по адресу http://jsperf.com/jquery-each-vs-quickeach, где также можно ознакомиться с результатами замеров производительности обоих методов.