вторник, 7 июня 2011 г.

Используем Microsoft Excel при помощи C# и .NET

Для того, что бы можно было начать работу с Microsoft Excel необходимо в проект добавить ссылку на COM компонент "Microsoft Excel 12.0 Object Library" после чего в проекте можно будет использовать классы из пространства имен Microsoft.Office.Interop.Excel.

Для быстрого старта и понимания работы с Microsoft Excel посредством в COM в C# достаточно базового примера - считывание из указанного файла .xlsx и запись в указанный файл. Я использовал .NET Framework 4 и Microsft Excel 2007. 

Код программы с комментариями: 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using MicrosoftExcel = 
    Microsoft.Office.Interop.Excel;

namespace MicrosoftExcelDemo
{
    class Program
    {
        static void Main(string[] args)
        {
            // создание объекта 
            // приложения
            MicrosoftExcel.Application application = 
                new MicrosoftExcel.Application();
            try 
            {
                // открытие диалогового 
                // окна для поиска файла 
                application.FindFile();
                // считывание данных из активного листа 
                ReadData(application.ActiveSheet);
                // запись в активный лист
                WriteData(application.ActiveSheet);                
            }
            catch(Exception e)
            {
                Console.WriteLine(
                    "Exception catched " + 
                    "with message: '{0}'", 
                    e.Message);
            }
            finally
            {
                // обязательное завершение
                // работы приложения 
                application.Quit();                            
            }
            Console.ReadKey();
        }

        static void ReadData(
            MicrosoftExcel.Worksheet workSheet)
        {
            // индексация в Microsoft Excel идет с 1
            // далее следует обход только 
            // используемой области активного листа 
            for (int row = 1; 
                row <= 
                  workSheet.UsedRange.Cells.Rows.Count; 
                row++)
            {
                for (int col = 1; 
                    col <= 
                      workSheet.UsedRange.Cells.Columns
                               .Count; 
                    col++)
                {
                    Console.Write(
                        "{0, 5} ", 
                        workSheet.UsedRange
                                 .Cells[row, col]
                                 .Value);
                }
                Console.WriteLine();
            }
        }

        static void WriteData(
            MicrosoftExcel.Worksheet workSheet)
        {
            for (int row = 1;
                row <= 
                  workSheet.UsedRange.Cells.Rows.Count; 
                row++)
            {
                for (int col = 1; 
                    col <= 
                      workSheet.UsedRange.Cells.Columns
                               .Count; 
                    col++)
                {
                    workSheet.UsedRange
                             .Cells[row, col]
                             .Value *= 10;
                }                
            }
        }
    }
}

Или вы можете скачать исходный код и файл с которым я работал здесь

Если возникнут вопросы или что-то не понятно, то обязательно спрашивайте, я всегда рад помочь! 

четверг, 17 марта 2011 г.

LinkDump #01

Я неделю назад опубликовал LinkDump #00 (18 ссылок). Я собираюсь попробовать продолжить данное начинание и публикую следующий список ссылок:

1. http://www.webmascon.com/topics/text/18a.asp

Перевод статьи Якоба Нильсена: "Перевернутые пирамиды в киберпространстве".

2. http://www.useit.com/alertbox/9704b.html

Jacob Nielsen: Do Websites Have Increasing Returns?

3. http://www.webmascon.com/topics/adv/7a.asp

Статья Якоба Нильсена, заметка к предыдущей ссылке: "Кривые Зипфа и популярность веб-сайтов".

4. http://www.webmascon.com/topics/adv/6a.asp

Краткая заметка Якоба Нильсена: Трафик от ссылающихся сайтов. 

5. http://www.webmascon.com/topics/business/9a.asp

Якоб Нильсен: Обманчивость нетипичных примеров.

6. http://www.webmascon.com/topics/business/16a.asp

Якоб Нильсена: Десять главных ошибок веб-менеджера.

7. http://www.insight-it.ru/programmirovanie/oop-ili-ne-oop/

ООП или не ООП.

8. http://citforum.ru/nets/protocols2/2_04_01.shtml

В сетях Ethernet используется метод доступа к среде передачи данных, называемый методом коллективного доступа с опознаванием несущей и обнаружением коллизий (carrier-sense-multiply-access with collision detection, CSMA/CD).

9. http://citforum.ru/nets/protocols2/2_04_00.shtml

Введение в стандарты технологии Ethernet.

10.  http://citforum.ru/nets/protocols2/2_04_02.shtml

Форматы кадров технологии Ethernet.

11. http://citforum.ru/nets/protocols2/2_04_03.shtml

Спецификации физической среды Ethernet.

12. http://citforum.ru/nets/protocols2/2_04_04.shtml

Ethernet: стандарт 10Base-5.

13. http://citforum.ru/nets/protocols2/2_04_05.shtml

Ethernet: стандарт 10Base-2. 

14. http://citforum.ru/nets/protocols2/2_04_08.shtml

Правило 4-х повторителей.

15. http://citforum.ru/nets/protocols2/2_04_09.shtml

Методика расчета конфигурации сети Ethernet.

16. http://citforum.ru/gazeta/167/

Почему предприятия не заинтересованы в NoSQL?

18. http://www.useit.com/alertbox/frequentbrowser.html

Frequent-Browser Programs

19. http://www.webmascon.com/topics/adv/3a.asp

Якоб Нильсен: Почему веб-зеваки ничего не стоят.

20. http://www.webmascon.com/topics/business/15a.asp

Постоянные посетители вашего Web-сайта.

21. http://rian.ru/politics/20110302/341088817.html

РИАНовости: За чистоту помыслов. Сюжет: 20 лет без СССР: анализ, комментарии, документы.

22. http://www.webmascon.com/topics/adv/2a.asp

Якоб Нильсен: Почему реклама не работает в Web.

23. http://citforum.ru/nets/protocols2/2_04_06.shtml

Ethernet: стандарт 10Base-T.

24.  http://citforum.ru/nets/protocols2/2_04_07.shtml

Ethernet: стандарт 10Base-F.

Итого вместе с первым linkdump у меня вышло 42 ссылки и это всего лишь за 2 недели. 

воскресенье, 13 марта 2011 г.

Один язык программирования на стороне клиента и сервера

О чем пойдет речь 

Я хочу поразмышлять на тему языков программирования под веб, а именно, меня интересует вопрос: "Можно ли выучить один или чуть более языков программирования и спокойно разрабатывать веб-приложения, как на стороне сервера, так и на стороне браузера?".

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

Какие проблемы (возможно надуманные) мы имеем на данный момент

Сейчас ситуация представляется мне так: под клиент (далее браузер) программируют используя javascript как язык программирования, также html, css, возможно xml, на сервере же (далее бекенд) ведется разработка на PHP, Java, Python, ASP.NET и даже Javascript! и других языках программирования. Также на бекенде работают с базой данной, зачастую используют язык SQL.

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

Но другое дело поддержка кода, это же сколько кода получается на разных языках, в следствии чего приходится переключаться, то Javascript, то PHP, то CSS, то HTML. Причем у каждого из этих языков свои тонкости, которые порой часто забываешь, да и просто сложно учитывать. Возьмите, например, даже тот же javascript, вы думаете, что знаете этот язык? Черта с два!

В следствие чего возникает проблема - постоянная мешанина кода и необходимость совершенствоваться в разных языках, учитывать тенденции развития нескольких языков. Наверное, это проблема надуманна, ибо я верю, что если код организован грамотно, то проблем с мешаниной и переключением контекста на разные языки не будет. Но даже если эта проблема надуманна, мне все равно хочется попробовать ее решить. Хочется провести, что-то вроде исследования: "какое минимальное количество языков, достаточно знать, что бы программировать под веб?".

Способ решения номер один: php_to_js($fileName)

Сразу, хочу представить один из забавных способов решения проблемы. Выглядит он следующим образом:

function php_to_js($fileName)
{
    $content = file_get_contents($fileName);
    return str_replace(
            array('', '$', '?>'),
            array('', '.', '', ''),
            $content);
}

Данный код всего лишь на всего заменяет свойственные символы для php на свойственные для javascript символы. Внимание! Это всего лишь набросок, так сказать, концепт более сложных движков.

Вот как мы это применим в html:

<!DOCTYPE HTML>
<html>
    <!-- head part -->
    <body>
        <div id="simpleDiv">Text</div>
        <input type="button" id="btn" 
                  value="click on me" />
    </body>
</html>

А вот сам example.php:

$window->onload = function()
{
    $document->getElementById('btn')
             ->onclick = function()
    {
        alert('Text changed');
        $document->getElementById('simpleDiv')
                 ->innerHTML = 'another text';
    };
};

В результате будет сгенерирован вполне работоспособный код javascript. Как мне кажется такой подход имеет право на жизнь, но если функция php_to_js будет более продвинута и т. д. и т. п. Одним из плюсов я бы, наверное, назвал, что php должен быть синтаксически правильно написан и IDE поможет вам в написании такого кода.

Способ решения номер два: javascript and backend handler

Есть другой способ, который мне более всего по душе, но это не чисто один язык. Суть в том, что вы пишете полностью приложение под браузер используя javascript. А когда вам необходимо достучатся к данным на сервере вы используете технологию ajax, причем на сервере скрипты на php или любом другом языке, пишутся легковесными, например, запрос к БД, и вывод ответа в виде json.

Наверное, один из плюсов такого подхода то, что почти вся логика будет на клиенте, хотя для некоторых видов приложений это может быть и минус. Причем логика эта описывается при помощи javascript. Тут главное следит за памятью и быстродействием, ибо вы не знаете, что там вас ждет на клиенте. У кого-то компьютер мощный, а у кого-то нет.

Способ решения номер три: nodejs 

Третий подход, который я нашел весьма популярным - это nodejs. Это популярный движок в последнее время. Суть его заключается в том, что вы пишете на сервере используя javascript - это весьма удобно, так как нужно будет всего лишь использовать один язык (если не считать HTML, CSS, SQL).

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

Итоги 

Вообщем, мне кажется, что тем, кто хочет "одноязычие" , еще стоит посмотреть в сторону технологии ASP.NET и глянуть на NodeJS

четверг, 10 марта 2011 г.

LinkDump #00

Я постоянно читаю статьи (также смотрю и слушаю подкасты) на разные темы и я даже больше чем уверен, что вы делаете тоже самое. Сфера интересов у меня возможно, не очень обширна, но все же я многими вещами интересуюсь и многие погремушки привлекают мое внимание.

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

Посты, я буду помечать ярлыком "ссылки", а первый LinkDump, я начну со следующих ссылок:

1. http://ru.wikipedia.org/wiki/Microsoft_Solutions_Framework

Microsoft Solutions Framework (MSF) — методология разработки программного обеспечения, предложенная корпорацией Microsoft. MSF опирается на практический опыт Microsoft и описывает управление людьми и рабочими процессами в процессе разработки решения.

MSF представляет собой согласованный набор концепций, моделей и правил.

2. http://www.rsdn.ru/article/philosophy/WhyOOP.xml

Почему объектно-ориентированное программирование провалилось?

3. http://rdos401.org/

К 15-летию русской версии MS-DOS.

4. http://bugtraq.ru/library/programming/objectshavefailed.html

Вводное выступление Ричарда П. Гэбриэла на диспуте по поводу ООП. 
Конференция OOPSLA, Сиэтл, 6 ноября 2002г.

5. http://bugtraq.ru/library/programming/objectshavenotfailed.html

Вводное выступление Гая Л. Стила на диспуте по поводу ООП. 
Конференция OOPSLA, Сиэтл, 6 ноября 2002г.

6. http://altdevblogaday.org/2011/02/12/alternatives-to-malloc-and-new/

Alternatives to malloc and new by Steven Tovey.

7. http://www.computerra.ru/hitech/35042/

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

8. http://channel9.msdn.com/Blogs/mikcher/249693

Юрий Стариков - первый советский гражданин в Microsoft.

9. http://channel9.msdn.com/Blogs/mikcher/249690

Как живет Microsoft? Игорь Бекельман и Людмила Фокина про Редмонд и округу.

10. http://channel9.msdn.com/Blogs/mikcher/415331

Алексей Пахунов про ядро Windows и поддержку 32-битных приложений. 

11. http://blog.not-a-kernel-guy.com/2008/11/13/373

Первое прямое наблюдение экзопланеты!

12. http://www.computerra.ru/xterra/34923/

Существует ли способ увеличить скорость человеческого мышления? Возможно ли каким-нибудь образом заставить человеческий мозг думать быстрее?

13. http://anton.shevchuk.name/my-life/story-about-god-dev/?utm_source=feedburner&utm_medium=feed&utm_campaign=Feed:+AntonShevchuk+(Anton+Shevchuk)

Сказка о программисте от Антона Шевчука. 

14. http://www.aiportal.ru/articles/neural-networks/1/

Набор статей, которые позволяет за короткие сроки разобраться в базовых понятиях нейронных сетей. 

15. http://pseudocoder.com/archives/you-dont-really-want-a-rock-star

I don't think I'm going out a limb when I say we (developers/designers) are sick of seeing "Rock Star" in job postings. Not only is it overused, it's not even analogous. Let's take a look at what a job posting would say if the company really wanted a "Rock Star" developer.

16. http://pseudocoder.com/archives/you-dont-really-want-a-ninja

Here's what a job posting would look like if the skills of a ninja were really applied to web dev.

17. http://pseudocoder.com/archives/the-type-of-employee-you-really-want-porn-star

So what kind of employee do you want? That's right: a Porn Star. Just checkout this job posting:

18. http://foundersblock.com/anecdotes/why-startups-fail-an-analysis-of-failure-post-mortems/

Why Startups Fail: An Analysis of Post-Mortems.

И еще вопрос: знаете ли вы какие-либо удобные сервисы для работы с ссылками и удобной организации оных по категориям? 

среда, 9 марта 2011 г.

Программа Paseek 2.5

При решении задач по криптографии часто возникает необходимость подобрать слово, например, имя существительное. В данном случае мне хорошо помогает программа Paseek 2.5. Также она может вам пригодиться, если вы:
  • решаете кроссворды;
  • угадываете анаграммы;
  • любите "словарные" головоломки. 
Если вы хотите сами во всем разобраться, то вы уже можете скачать программу, в противном случае, я расскажу вам как я пользовался данной программой, что в ней есть и что она умеет. 

Главное окно условно разделено на 2 части, слева словарь со словами, а справа утилиты для работы со словарем.



Справа снизу в текстовом поле можно вводить слова или часть слова, а также производить поиск по шаблону. Справа есть раздел кроссворд, а у него подпункт "Новый поиск..." - это тот же самый поиск, что в текстовом поле снизу. Приведу несколько шаблонов, которыми я часто пользуюсь:

  • "а??а??" - в данном случае слово должно состоять из 6 букв, а на 1 и 4 позиции слова должна быть буква "а".
  • "?????" - слово из 5 букв.
  • "аб*вд" - слова которые начинаются на "аб" и заканчиваются на "вд", а между началом и окончанием любое количество букв. 
  • "п!+р!+" - слово из 4 букв, где вместо комбинации символов "!+" может быть любая гласная, для согласных нужно использовать "+". 
Справа ниже под пунктом кроссворд, есть пункт "Анаграммы", там так же нужно нажать "Новый поиск...", суть поиска в данном случае заключается в том, что программа просто решает анаграмму и находит правильное слово. 

Также есть раздел с палиндромами. Палиндром - это такое слово, которое с двух сторон читается одинаково, например "доход". В данном случае в программе можно просто просмотреть список палиндромов. 

Если в верхнем меню нажать "Поиск", а затем "Цепочка слов..." или комбинацию клавиш "Ctrl+W", то можно воспользоватся утилитой которое позволяет изменяя букву за буквой (или сразу несколько букв) превратить одно слово в другое. 



Также программа позволяет создавать и работать со своими словарями и настраивать внешний вид. Если у вас возникнут сложности в использовании программы - обращайтесь (я не являюсь автором программы)! 

Шифр Полибия

Искал книгу по криптографии, написал в поисковике "книга по криптографии". Зашел кажется на второй или на третий результат и увидел следующее (нажмите на изображение, что бы его приблизить):


Сегодня речь пойдет, а самом используемом шифре, правда не в данное время, а вообще за всю историю криптографии. Я расскажу о шифре Полибия, его можно отнести к классу исторических шифров, так как он в наше время уже не используется. Но в свое время, это был "прорыв", так как тексты зашифрованные шифром Полибия, были более устойчивые, чем тексты зашифрованные шифром сциталы (шифр Древней Спарты), шифром Цезаря или Августа (шифр Цезаря или Августа появились после шифра Полибия) и т. п.

Попробуем зашифровать текст шифром Полибия. Для этого возьмем квадрат с размерами 5x5 и впишем в него буквы латинского алфавита, причем I,J пусть будут в одной клетке:


Нумеровать столбцы или строки можно по-разному: буквами, цифрами, каким-то словом и так далее. И буквы в квадрат моут быть вписаны в случайном порядке. Тогда имея данный квадрат (ключ зашифрования) мы для каждой буквы в сообщении выписываем ее координаты, можно сначала строку, а потом столбец или наоборот. Я буду использовать сначала строку, а потом столбец, Например, зашифруем слово "cipher":

m = "cipher"
c = "13,24,35,23,15,42"

Можно разделитель и не использовать. Таким образом, мы получили шифр текст. Прямая атака (методом перебора) здесь не пройдет, так как имеется, примерно, 15511210043331000000000000 вариантов ключ. Но, но, но...

Для данного шифра можно использовать частотный анализ. Это простой статистический подход, в котором учитываются частоты букв. Для латинского алфавита (как и для любых других) известны частоты появления букв в тексте. Например, известно, что среди 1000 букв в обычном русском тексте, буква "О" встречается примерно 90 раз (частота 0,090). Так как шифр Полибия является шифром замены, то есть такой в котором все буквы исходного текста заменяются вполне определенными последовательностями, то частоты распространяются и на закодированное сообщение. Следовательно, можно с легкостью применить частотный анализ, правда на текстах, длина которых, хотя бы более 50 букв. Поэтому-то этот шифр и не считается стойким, что и естественно для шифра разработанного в 2 веке до н.э!

Теперь задание, вы можете скачать его отсюда. Известно, что используется квадрат с русским алфавитом, где буква ё=е, также используется пробел, точка и запятая. Известно, что строки и столбцы нумеруются с 0 до 5, то есть квадрат имеет размеры 6x6 (по шифр-тексту видно).

Попробуйте, провести атаку используя частотный анализ (частотный словарь вы можете поискать в интернете), если у вас все же не получиться провести атаку, тогда вы можете скачать ответ, но учтите, нужно потратить хотя бы одну неделю на решение задачи, а иначе не будет проку.

При решении вам можете пригодиться программа Paseek 2.5. Я ее использую для подбора имен существительных.

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

Тип работника который вам по-настоящему нужен: порно-звезда

Данная статья является переводом статьи The Type of Employee You Really Want: Porn Star.

Последние два дня мы говорили о том, почему вам не нужна рок-звезда или ниндзя в качестве работника. Так какой же тип работника вам нужен? Правильно - порно-звезда. Просто взгляните на следующее объявление о работе. 

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

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

Вы должны обладать высочайшим уровнем выносливости в кодировании и давать большие результаты. Вы должны будете часами работать над одной и той же задачей и не скучать.

Вы получите очень маленькое направление, так что ожидается, что вы понимаете, что вы делаете. Это будет естественно для вас.

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

Мы не большая команда, поэтому вы со временем привыкните носить одежду чистильщика бассейна, доставщика пиццы или ремонтника серверов.

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

Мы большие поклонники тестирования. Мы прогоняем весь набор тестов после фиксации каждого "бага".  Если ваш код не будет проходить тест, то вы не сможете заняться ничем другим до тех пор, пока не будет выяснена причина ошибки.

Мы компания людей, которые заканчивают начатое. Если мы начали проект, мы должны завершить его.

Мы ожидаем тонны пользователей при выпуске нашего продукта. Эта штука выстрелит и мы будем круче, чем TechCrunch.