입력
1. readline 모듈
처음 생성 시 createInterface를 통해 input, output을 설정해준다.
다음에, 입력을 갖고 처리할 callback함수인 function(line)을 설정해준다.
기본적으로 매개변수 line에 할당되는 것이 입력값이며, 문자열로 할당된다.
const readline = require('readline');
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout
});
let input = [];
rl.on('line', function (line) {
// 입력 처리
//input = line.split(' ').map((el) => parseInt(el));
})
.on('close', function () {
// 출력
//console.log();
process.exit();
});
2. fs 모듈
fs 모듈은 FileSystem의 약자로 파일 처리와 관련된 모듈이다.
2-1) readFile()
filename의 파일을 [options]의 방식으로 읽은 후 callback으로 전달된 함수를 호출한다. (비동기적)
fs.readFile(filename, [options], callback)
2-2) readFileSync()
filename의 파일을 [options]의 방식으로 읽은 후 문자열을 반환한다. (동기적)
fs.readFileSync(filename, [options])
Sync가 붙은 것은 동기적 읽기, 붙지 않은 것은 비동기적 읽기이다.
동기적 읽기로 읽게 되면 파일을 읽으면서 다른 작업을 동시에 할 수 없다.
하지만 비동기적으로 읽으면 파일을 읽으면서 다른 작업도 동시에 수행할 수 있고,
파일을 다 읽으면 매개변수 callback으로 전달한 함수가 호출된다.
[options]에는 보통 인코딩 방식이 오게 되며 웹에서는 utf8을 주로 사용한다.
// 문자 하나만 입력받을 경우
let input = require("fs").readFileSync("/dev/stdin").toString()
//숫자로 변환
let num = Number(input)
// 한칸 띄어쓰기로 구분
// input[0], input[1] 배열에서 꺼내쓰면 된다.
let input = require("fs").readFileSync("/dev/stdin").toString().split(" ")
// 줄바꿈으로 구분
let input = require("fs").readFileSync("/dev/stdin").toString().split("\n")
let count = input[0];
let numbers = [];
for (let i = 1; i < input.length; i++) {
if (input[i] !== '') {
numbers.push(input[i].split(' '));
}
}
for (let i = 0; i < numbers.length; i++){
let num1 = Number(numbers[i][0]);
let num2 = Number(numbers[i][1]);
//console.log(num1 + num2);
}
출력
console.log()
[출처]
https://velog.io/@hjkdw95/%EB%B0%B1%EC%A4%80-Node.js-%EC%9E%85%EC%B6%9C%EB%A0%A5-%EC%A0%95%EB%A6%AC
https://velog.io/@exploit017/%EB%B0%B1%EC%A4%80Node.js-Node.js-%EC%9E%85%EB%A0%A5-%EB%B0%9B%EA%B8%B0
'Coding > Reference' 카테고리의 다른 글
Visual Studio Code에서 C# 실행 (0) | 2021.09.27 |
---|---|
Visual Studio Code에서 JavaScript 실행 (0) | 2021.09.10 |
JavaScript 사용할 때 주의할 점 (0) | 2021.08.24 |