UNPKG

workshopper-browser-guide

Version:

Create an html browser version of the exercise descriptions

94 lines (88 loc) 5.89 kB
<!doctype html> <html class="no-js" lang="ru"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>learnyounode Guide</title> <meta name="description" content="learn git and github"> <meta name="viewport" content="width=device-width, initial-scale=1"> <link rel="stylesheet" href="assets/css/style.css"> <link rel="stylesheet" href="assets/css/code.css"> <link href='assets/fonts/fonts.css' rel='stylesheet' type='text/css'> </head> <body> <!--[if lt IE 8]> <p class="browsehappy">You are using an <strong>outdated</strong> browser. Please <a href="http://browsehappy.com/">upgrade your browser</a> to improve your experience.</p> <![endif]--> <header class="site-header"> <div class="nav u-posFixed"> <ul class="nav-lang"> <li><a href="my_first_io.html" >English</a></li> <li><a href="my_first_io.es.html" >Español</a></li> <li><a href="my_first_io.ja.html" >日本語</a></li> <li><a href="my_first_io.pt-br.html" >Português (Brasil)</a></li> <li><a href="my_first_io.ru.html" >Русский</a></li> <li><a href="my_first_io.zh-cn.html" >中文 (中国)</a></li> <li><a href="my_first_io.zh-tw.html" >中文 (臺灣)</a></li> </ul> <div class="wrap-width u-textCenter"> <a href="baby_steps.ru.html" <span class="u-floatLeft hand"></span> </a> <a class="filledblock" href="index.ru.html">learnyounode</a> <a href="my_first_async_io.ru.html" <span class="u-floatRight hand"></span> </a> </div> </div> <div class="wrapper"> <div class="u-floatLeft"> <span class="all-caps">CHALLENGE</span> <h2 class="challenge-name">MY FIRST I/O!</h2> </div> <div class="u-floatRight u-textRight"> <span class="all-caps">NUMBER</span> <h2 class="challenge-name">3 / 13</h2> </div> </div> </header> <div class="wrapper"> <p>Реализуйте программу, которая <em>синхронно</em> читает файл и выводит количество, строк содержащихся в файле, в консоль (stdout), точно так же, как это сделала бы команда <code>cat file | wc -l</code>.</p> <p>Полный путь до файла будет передан в качестве первого аргумента командной строки.</p> <hr> <h2 id="-">ИНФОРМАЦИЯ</h2> <p>Для того чтобы прочитать файл Вам понадобится модуль <code>fs</code> из встроенной библиотеки Node. Для того чтобы загрузить этот, или любой другой, модуль из этой библиотеки воспользуйтесь следующей конструкцией:</p> <pre><code class="lang-js"><span class="hljs-keyword">var</span> fs = <span class="hljs-built_in">require</span>(<span class="hljs-string">'fs'</span>) </code></pre> <p>Таким образом <code>fs</code> модуль будет доступен в переменной <code>fs</code>. </p> <p>Все синхронные (или блокирующие) методы файловой системы в <code>fs</code> оканчиваются на <code>Sync</code>. Для того чтобы прочитать файл Вам понадобится <code>fs.readFileSync(&#39;/path/to/file&#39;)</code>. Этот метод вернет объект типа <code>Buffer</code> содержащий весь контент файла.</p> <p>Документацию для <code>fs</code> модуля вы сможете найти набрав в браузере: <a href="../node_apidoc/fs.html">/node_apidoc/fs.html</a></p> <p>Объекты типа <code>Buffer</code> используются Node для эффективного представления массивов данных, будь это ascii, бинарный или любой другой формат. Эти объекты могут быть конвертированы в строки путем вызовом метода <code>toString()</code> над ними, например <code>var str = buf.toString()</code>.</p> <p>Документацию для <code>Buffer</code> вы сможете найти набрав в браузере: <a href="../node_apidoc/buffer.html">/node_apidoc/buffer.html</a></p> <p>Если Вы ищите простой способ посчитать строк в строке, то Вы можете использовать <code>.split()</code> с разделителем <code>\n</code> для разбиения этой строки на массив подстрок. Примите во внимание то, что тестовый файл не содержит символ <code>\n</code> в конце последней строки, таки образом у вас получится массив который содержит на один элемент больше чем число строк в файле. </p> <hr> <div class="prenext"> <div class="u-floatLeft"> <a href="baby_steps.ru.html" class="u-inline-block all-caps">BABY STEPS <div></div> </a> </div> <div class="u-textRight u-floatRight"> <a href="my_first_async_io.ru.html" class="u-inlineBlock all-caps">MY FIRST ASYNC I/O! <div></div> </a> </div> </div> <footer> <!-- <ul> <li class="all-caps"><a href="index.html"><strong>Challenges</strong></a></li> <li class="all-caps"> <a href="https://github.com/rvagg/learnyounode/issues/new" target="_blank">Open an Issue</a> </li> </ul> --> </footer> </div> </body> </html>