* Windows 10 Pro


1.

 : 하기의 URL을 통해 python 내려받기

  > https://www.python.org/downloads/


2.

 : python-3.7.1 실행 후 다음과 같이 설정 후 Install Now 클릭


3.


4.

 : 경로 길이 제한을 해제하기 위해 Disable path length limit를 클릭


5.

 : 설치 완료 메세지가 출력되면 Close 버튼 클릭하여 마무리


6.


7.

 : 고급 탭 클릭 후 하단의 환경 변수(N)... 버튼 클릭


8.

 : Admin에 대한 사용자 변수(U) 목록 중 Path를 찾아 편집 버튼 클릭, 여기서 Admin은 User Name 이므로 환경마다 다를 수 있음


9.

 : 다음과 같이 Python37-3 관련 2개의 환경 변수가 설정되어 있는 것을 확인 가능


10.


11.

 : python 버전 정보 확인, 여기서 옵션 V는 대문자




* Windows 10 Pro


1.

 : https://nodejs.org/ko/

 : 10.12.0 현재 버전 클릭


2.


3.


4.


5.


6.


7.


8.


9.


10.


11.

 : 환경 변수(N)... 버튼 클릭


12.

 : 시스템 변수(S) > Path > 편집(I)...


13.

 : 환경 변수 등록 여부 확인


14.


15.



'Programming > Node.js' 카테고리의 다른 글

node.js 시작하기  (0) 2018.06.18
node-v7.4.0-x64 설치 및 환경 구축  (0) 2017.01.24


다음과 같은 에러 발생 시

1
2
3
4
5
6
7
8
9
10
11
---------------------------------------------------------------------------
NameError                                 Traceback (most recent call last)
<ipython-input-54-9b9440005e62> in <module>()
     35 
     36 
---> 37 for i in xrange(num_vectors):
     38   if np.random.random() > 0.5:
     39     x_values.append(np.random.normal(0.4, 0.7))
 
NameError: name 'xrange' is not defined
 
cs


파이썬 2.x 에서 3.x 로 변경되면서 range 로 변경되었음.



OS : Windows 10

Py: 2.7.15


1.

 : https://www.python.org/downloads/


2.


3.


4.


5.


6.


7.


환경 변수 설정

8.


9.


10.


* 편집 전에 python27의 경로를 확인


11.


12.


13.

1
2
3
C:\Users\Admin>python --version
Python 2.7.15
 
cs



사이썬(Cython)

 : 컴퓨터의 실제 하드웨어에 가까울수록 처리해야 할 데이터의 타입을 아는 것이 중요하다. 컴퓨터 입장에서는 1 + 1과 1.00 + 1.00은 다르다. 전자는 정수들로 이뤄져 있지만, 후자는 부동소수점수이다. 정수를 계산할 때와 부동소수점수를 계산할 때, 계산이 CPU의 서로 다른 부분에서 이뤄진다. 파이썬에서는 사용하려는 데이터의 타입을 명시할 필요가 없이 파이썬 컴파일러가 타입을 유추한다. 하지만 데이터 타입 추론은 느린 연산이므로 파이썬의 속도를 떨어뜨리는 데에 한몫한다. 사이썬에서는 프로그램을 개발하는 프로그래머가 데이터 타입을 반드시 지정하도록 함으로써 이 문제를 해결했다. 컴파일러가 이 정보를 갖고 있으면 훨씬 빠르게 동작할 수 있다.


넘엑스퍼(Numexpr)

 : 인메모리 패키지에 NumPy가 있다면 빅데이터 패키지의 핵심에는 Numexpr가 있다. Numexpr는 NumPy의 숫자 표현식 평가이지만, 원래의 NumPy보다 몇 배나 빠르다. 표현식을 재작성하고 내부의 JIT(just-in-time) 컴파일러를 사용함으로써 높은 성능을 낸다.


넘바(Numba)

 : Numba는 코드를 실행 직전에 컴파일하는 JIT 컴파일 기법을 이용해 속도를 향상시킨다. 고수준 코드를 작성하면서도 C 코드처럼 빠른 속도를 얻을 수 있다. Numba의 사용법은 직관적이다.


비칼즈(Bcolz)

 : Bcolz는 NumPy를 사용할 때 일어날 수 있는 메모리 부족 문제를 극복하도록 돕는다. Bcolz는 최적화된 압축 형태의 배열에 저장해 작업할 수 있다. 데이터를 슬림하게 만들뿐 아니라 후면에서 Numexpr를 사용해 bcolz 배열을 가지고 계산을 수행할 때 필요한 계산을 줄인다.


블레이즈(Blaze)

 : '파이썬 다운 방식'으로 데이터베이스 후단부(back-end)를 다루고 싶다면 Blaze가 제격이다. 파이썬 코드를 SQL로 번역해줄 뿐만 아니라 관계형 데이터베이스 외에도 CSV나 스파크와 같은 것을 다룰 수도 있다. Blaze를 사용함으로써 여러 데이터베이스와 데이터 라이브러리를 일관적인 방식으로 다룰 수 있다. Blaze는 지금도 개발되고 있어서 모든 기능이 구현되지는 않았다.


테아노(Theano)

 : 테아노는 그래픽 처리 장치를 가지고 직접 작업할 수 있게 해주고 , 수식을 단순화하며, 훌륭한 JIT 컴파일러를 내장하고 있다. 그러한 바탕 위에서 유용한 고등 수학 개념인 텐서를 다루는 훌륭한 라이브러리다.


다스크(Dask)

 : Dask는 계산의 흐름을 최적화하고 효율적으로 수행시킨다. 계산을 분배할 수도 있다.



출처: 파이썬으로 배우는 데이터 과학 입문과 실습 소규모 데이터셋 처리부터 빅데이터 처리, 머신러닝, 시각화까지

출처: http://abc2080.tistory.com/entry/파이썬을-이용한-머신러닝-관련-패키지 [Another Windows]

출처: 파이썬으로 배우는 데이터 과학 입문과 실습 소규모 데이터셋 처리부터 빅데이터 처리, 머신러닝, 시각화까지



os: windows 10

node: 7.4.0


1. node.js를 시작할 폴더의 경로를 지정하여 다음의 명령어를 실행합니다.

npm은 프로젝트 구성을 위해 몇 가지 파라미터를 요청하므로 적절히 입력 후 엔터

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
C:\Users\Admin\Downloads\node>npm init
This utility will walk you through creating a package.json file.
It only covers the most common items, and tries to guess sensible defaults.
 
See `npm help json` for definitive documentation on these fields
and exactly what they do.
 
Use `npm install <pkg> --save` afterwards to install a package and
save it as a dependency in the package.json file.
 
Press ^C at any time to quit.
name: (node) rabbit
version: (1.0.0)
description:
entry point: (index.js)
test command:
git repository:
keywords:
author:
license: (ISC)
About to write to C:\Users\Admin\Downloads\node\package.json:
 
{
  "name": "rabbit",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}
 
 
Is this ok? (yes) yes
 
cs



2. 2~3번 과정은 추후 사용할 프레임워크 및 툴이므로 필요치 않을 경우 하지 않아도 무방합니다.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
C:\Users\Admin\Downloads\node>npm install --save seneca
rabbit@1.0.0 C:\Users\Admin\Downloads\node
`-- seneca@3.6.0
  +-- archy@1.0.0
  +-- eraro@1.0.0
  +-- gate-executor@1.1.1
  +-- gex@0.3.0
  +-- json-stringify-safe@5.0.1
  +-- jsonic@0.3.0
  +-- lodash@4.17.10
  +-- minimist@1.2.0
  +-- nid@0.3.2
  +-- norma@0.4.1
  +-- ordu@0.1.1
  +-- patrun@1.0.0
  +-- qs@6.5.2
  +-- rolling-stats@0.1.1
  +-- semver@5.5.0
  +-- seneca-transport@2.3.0
  | +-- lru-cache@4.1.3
  | | +-- pseudomap@1.0.2
  | | `-- yallist@2.1.2
  | +-- ndjson@1.5.0
  | | +-- split2@2.2.0
  | | `-- through2@2.0.3
  | |   +-- readable-stream@2.3.6
  | |   | +-- core-util-is@1.0.2
  | |   | +-- inherits@2.0.3
  | |   | +-- isarray@1.0.0
  | |   | +-- process-nextick-args@2.0.0
  | |   | +-- safe-buffer@5.1.2
  | |   | +-- string_decoder@1.1.1
  | |   | `-- util-deprecate@1.0.2
  | |   `-- xtend@4.0.1
  | `-- reconnect-core@1.3.0
  |   `-- backoff@2.5.0
  |     `-- precond@0.2.3
  +-- use-plugin@1.0.2
  `-- wreck@12.5.1
    +-- boom@5.2.0
    `-- hoek@4.2.1
 
npm WARN rabbit@1.0.0 No description
npm WARN rabbit@1.0.0 No repository field.
 
cs



3.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
C:\Users\Admin\Downloads\node>npm install -g pm2
C:\Users\Admin\AppData\Roaming\npm\pm2-runtime -> C:\Users\Admin\AppData\Roaming\npm\node_modules\pm2\bin\pm2-runtime
C:\Users\Admin\AppData\Roaming\npm\pm2-dev -> C:\Users\Admin\AppData\Roaming\npm\node_modules\pm2\bin\pm2-dev
C:\Users\Admin\AppData\Roaming\npm\pm2-docker -> C:\Users\Admin\AppData\Roaming\npm\node_modules\pm2\bin\pm2-docker
C:\Users\Admin\AppData\Roaming\npm\pm2 -> C:\Users\Admin\AppData\Roaming\npm\node_modules\pm2\bin\pm2
C:\Users\Admin\AppData\Roaming\npm
`-- pm2@2.10.4
  +-- async@2.6.1
  | `-- lodash@4.17.10
  +-- blessed@0.1.81
  +-- chalk@1.1.3
  | +-- ansi-styles@2.2.1
  | +-- escape-string-regexp@1.0.5
  | +-- has-ansi@2.0.0
  | | `-- ansi-regex@2.1.1
  | +-- strip-ansi@3.0.1
  | `-- supports-color@2.0.0
  +-- chokidar@2.0.3
  | +-- anymatch@2.0.0
  | | `-- micromatch@3.1.10
  | |   +-- arr-diff@4.0.0
  | |   +-- define-property@2.0.2
  | |   | `-- is-descriptor@1.0.2
  | |   |   +-- is-accessor-descriptor@1.0.0
  | |   |   `-- is-data-descriptor@1.0.0
  | |   +-- extend-shallow@3.0.2
  | |   | +-- assign-symbols@1.0.0
  | |   | `-- is-extendable@1.0.1
  | |   |   `-- is-plain-object@2.0.4
  | |   +-- extglob@2.0.4
  | |   | +-- define-property@1.0.0
  | |   | | `-- is-descriptor@1.0.2
  | |   | |   +-- is-accessor-descriptor@1.0.0
  | |   | |   `-- is-data-descriptor@1.0.0
  | |   | +-- expand-brackets@2.1.4
  | |   | | +-- debug@2.6.9
  | |   | | +-- define-property@0.2.5
  | |   | | +-- extend-shallow@2.0.1
  | |   | | `-- posix-character-classes@0.1.1
  | |   | `-- extend-shallow@2.0.1
  | |   +-- fragment-cache@0.2.1
  | |   +-- kind-of@6.0.2
  | |   +-- nanomatch@1.2.9
  | |   | +-- is-odd@2.0.0
  | |   | | `-- is-number@4.0.0
  | |   | `-- is-windows@1.0.2
  | |   +-- object.pick@1.3.0
  | |   `-- regex-not@1.0.2
  | +-- async-each@1.0.1
  | +-- braces@2.3.2
  | | +-- arr-flatten@1.1.0
  | | +-- array-unique@0.3.2
  | | +-- extend-shallow@2.0.1
  | | | `-- is-extendable@0.1.1
  | | +-- fill-range@4.0.0
  | | | +-- extend-shallow@2.0.1
  | | | +-- is-number@3.0.0
  | | | | `-- kind-of@3.2.2
  | | | |   `-- is-buffer@1.1.6
  | | | +-- repeat-string@1.6.1
  | | | `-- to-regex-range@2.1.1
  | | +-- isobject@3.0.1
  | | +-- repeat-element@1.1.2
  | | +-- snapdragon@0.8.2
  | | | +-- base@0.11.2
  | | | | +-- cache-base@1.0.1
  | | | | | +-- collection-visit@1.0.0
  | | | | | | +-- map-visit@1.0.0
  | | | | | | `-- object-visit@1.0.1
  | | | | | +-- get-value@2.0.6
  | | | | | +-- has-value@1.0.0
  | | | | | | `-- has-values@1.0.0
  | | | | | |   `-- kind-of@4.0.0
  | | | | | +-- set-value@2.0.0
  | | | | | | `-- extend-shallow@2.0.1
  | | | | | +-- to-object-path@0.3.0
  | | | | | | `-- kind-of@3.2.2
  | | | | | +-- union-value@1.0.0
  | | | | | | `-- set-value@0.4.3
  | | | | | |   `-- extend-shallow@2.0.1
  | | | | | `-- unset-value@1.0.0
  | | | | |   `-- has-value@0.3.1
  | | | | |     +-- has-values@0.1.4
  | | | | |     `-- isobject@2.1.0
  | | | | +-- class-utils@0.3.6
  | | | | | +-- arr-union@3.1.0
  | | | | | +-- define-property@0.2.5
  | | | | | `-- static-extend@0.1.2
  | | | | |   +-- define-property@0.2.5
  | | | | |   `-- object-copy@0.1.0
  | | | | |     +-- copy-descriptor@0.1.1
  | | | | |     +-- define-property@0.2.5
  | | | | |     `-- kind-of@3.2.2
  | | | | +-- component-emitter@1.2.1
  | | | | +-- define-property@1.0.0
  | | | | | `-- is-descriptor@1.0.2
  | | | | |   +-- is-accessor-descriptor@1.0.0
  | | | | |   `-- is-data-descriptor@1.0.0
  | | | | +-- mixin-deep@1.3.1
  | | | | | +-- for-in@1.0.2
  | | | | | `-- is-extendable@1.0.1
  | | | | `-- pascalcase@0.1.1
  | | | +-- debug@2.6.9
  | | | +-- define-property@0.2.5
  | | | | `-- is-descriptor@0.1.6
  | | | |   +-- is-accessor-descriptor@0.1.6
  | | | |   | `-- kind-of@3.2.2
  | | | |   +-- is-data-descriptor@0.1.4
  | | | |   | `-- kind-of@3.2.2
  | | | |   `-- kind-of@5.1.0
  | | | +-- extend-shallow@2.0.1
  | | | +-- map-cache@0.2.2
  | | | +-- source-map@0.5.7
  | | | +-- source-map-resolve@0.5.2
  | | | | +-- atob@2.1.1
  | | | | +-- decode-uri-component@0.2.0
  | | | | +-- resolve-url@0.2.1
  | | | | +-- source-map-url@0.4.0
  | | | | `-- urix@0.1.0
  | | | `-- use@3.1.0
  | | +-- snapdragon-node@2.1.1
  | | | +-- define-property@1.0.0
  | | | | `-- is-descriptor@1.0.2
  | | | |   +-- is-accessor-descriptor@1.0.0
  | | | |   `-- is-data-descriptor@1.0.0
  | | | `-- snapdragon-util@3.0.1
  | | |   `-- kind-of@3.2.2
  | | +-- split-string@3.1.0
  | | `-- to-regex@3.0.2
  | |   `-- safe-regex@1.1.0
  | |     `-- ret@0.1.15
  | +-- glob-parent@3.1.0
  | | +-- is-glob@3.1.0
  | | `-- path-dirname@1.0.2
  | +-- inherits@2.0.3
  | +-- is-binary-path@1.0.1
  | | `-- binary-extensions@1.11.0
  | +-- is-glob@4.0.0
  | | `-- is-extglob@2.1.1
  | +-- normalize-path@2.1.1
  | | `-- remove-trailing-separator@1.1.0
  | +-- path-is-absolute@1.0.1
  | +-- readdirp@2.1.0
  | | +-- graceful-fs@4.1.11
  | | +-- minimatch@3.0.4
  | | | `-- brace-expansion@1.1.11
  | | |   +-- balanced-match@1.0.0
  | | |   `-- concat-map@0.0.1
  | | +-- readable-stream@2.3.6
  | | | +-- core-util-is@1.0.2
  | | | +-- isarray@1.0.0
  | | | +-- process-nextick-args@2.0.0
  | | | +-- safe-buffer@5.1.2
  | | | +-- string_decoder@1.1.1
  | | | `-- util-deprecate@1.0.2
  | | `-- set-immediate-shim@1.0.1
  | `-- upath@1.1.0
  +-- cli-table-redemption@1.0.1
  +-- commander@2.13.0
  +-- cron@1.3.0
  | `-- moment-timezone@0.5.18
  +-- debug@3.1.0
  | `-- ms@2.0.0
  +-- eventemitter2@1.0.5
  +-- fclone@1.0.11
  +-- gkt@1.0.0
  +-- mkdirp@0.5.1
  | `-- minimist@0.0.8
  +-- moment@2.22.2
  +-- needle@2.2.1
  | +-- debug@2.6.9
  | +-- iconv-lite@0.4.23
  | | `-- safer-buffer@2.1.2
  | `-- sax@1.2.4
  +-- nssocket@0.6.0
  | +-- eventemitter2@0.4.14
  | `-- lazy@1.0.11
  +-- pidusage@1.2.0
  +-- pm2-axon@3.1.0
  | +-- amp@0.3.1
  | +-- amp-message@0.1.2
  | `-- escape-regexp@0.0.1
  +-- pm2-axon-rpc@0.5.1
  +-- pm2-deploy@0.3.9
  | +-- async@1.5.2
  | `-- tv4@1.3.0
  +-- pm2-multimeter@0.1.2
  | `-- charm@0.1.2
  +-- pmx@1.6.7
  | +-- deep-metrics@0.0.1
  | +-- json-stringify-safe@5.0.1
  | `-- vxx@1.2.2
  |   +-- continuation-local-storage@3.2.1
  |   | +-- async-listener@0.6.9
  |   | `-- emitter-listener@1.1.1
  |   +-- debug@2.6.9
  |   +-- extend@3.0.1
  |   +-- is@3.2.1
  |   +-- lodash.findindex@4.6.0
  |   +-- lodash.isequal@4.5.0
  |   +-- lodash.merge@4.6.1
  |   +-- methods@1.1.2
  |   +-- shimmer@1.2.0
  |   `-- uuid@3.2.1
  +-- promptly@2.2.0
  | `-- read@1.0.7
  |   `-- mute-stream@0.0.7
  +-- semver@5.5.0
  +-- shelljs@0.7.8
  | +-- glob@7.1.2
  | | +-- fs.realpath@1.0.0
  | | +-- inflight@1.0.6
  | | | `-- wrappy@1.0.2
  | | `-- once@1.4.0
  | +-- interpret@1.1.0
  | `-- rechoir@0.6.2
  |   `-- resolve@1.8.1
  |     `-- path-parse@1.0.5
  +-- source-map-support@0.5.6
  | +-- buffer-from@1.1.0
  | `-- source-map@0.6.1
  +-- sprintf-js@1.1.1
  +-- v8-compile-cache@1.1.2
  +-- vizion@0.2.13
  | `-- async@1.5.2
  `-- yamljs@0.3.0
    `-- argparse@1.0.10
      `-- sprintf-js@1.0.3
 
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@^1.1.2 (node_modules\pm2\node_modules\chokidar\node_modules\fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.2.4: wanted {"os":"darwin","arch":"any"} (current: {"os":"win32","arch":"x64"})
 
cs



4. 해당 폴더에 app.js 파일 작성




5. app.js 코드

1
2
3
4
5
6
7
8
9
var http = require('http');
 
var server = http.createServer(function(request, response) {
    response.writeHead(200, { "Content-Type": "text/plain" });
    response.end("Hello World\n");
});
 
server.listen(8000);
 
cs



6. 웹 브라우저에서 출력 확인

* 브라우저의 환경에 따라 "localhost:8000" 으로 접속되지 않을 경우 "http://127.0.0.1:8000/" 를 입력합니다.



'Programming > Node.js' 카테고리의 다른 글

node-v10.12.0-x64 설치 및 환경 구축  (0) 2018.10.20
node-v7.4.0-x64 설치 및 환경 구축  (0) 2017.01.24


아래와 같은 에러 발생 시

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# pip install --upgrade pyodbc
Collecting pyodbc
  Using cached pyodbc-4.0.22.tar.gz
Building wheels for collected packages: pyodbc
  Running setup.py bdist_wheel for pyodbc ... error
  Complete output from command /usr/bin/python3 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-uy211_p4/pyodbc/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('\r\n', '\n');f.close();exec(compile(code, __file__, 'exec'))" bdist_wheel -d /tmp/tmpun36g10hpip-wheel- --python-tag cp34:
  running bdist_wheel
  running build
  running build_ext
  building 'pyodbc' extension
  creating build
  creating build/temp.linux-x86_64-3.4
  creating build/temp.linux-x86_64-3.4/src
  x86_64-linux-gnu-gcc -pthread -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -g -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -D_FORTIFY_SOURCE=2 -fPIC -DPYODBC_VERSION=4.0.22 -I/usr/include/python3.4m -c src/errors.cpp -o build/temp.linux-x86_64-3.4/src/errors.o -Wno-write-strings
  cc1plus: warning: command line option ‘-Wstrict-prototypes’ is valid for C/ObjC but not for C++ [enabled by default]
  In file included from src/errors.cpp:2:0:
  src/pyodbc.h:56:17: fatal error: sql.h: No such file or directory
   #include <sql.h>
                   ^
  compilation terminated.
  error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
 
  ----------------------------------------
  Failed building wheel for pyodbc
  Running setup.py clean for pyodbc
Failed to build pyodbc
Installing collected packages: pyodbc
  Running setup.py install for pyodbc ... error
    Complete output from command /usr/bin/python3 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-uy211_p4/pyodbc/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('\r\n', '\n');f.close();exec(compile(code, __file__, 'exec'))" install --record /tmp/pip-2segjg5z-record/install-record.txt --single-version-externally-managed --compile:
    running install
    running build
    running build_ext
    building 'pyodbc' extension
    creating build
    creating build/temp.linux-x86_64-3.4
    creating build/temp.linux-x86_64-3.4/src
    x86_64-linux-gnu-gcc -pthread -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -g -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -D_FORTIFY_SOURCE=2 -fPIC -DPYODBC_VERSION=4.0.22 -I/usr/include/python3.4m -c src/errors.cpp -o build/temp.linux-x86_64-3.4/src/errors.o -Wno-write-strings
    cc1plus: warning: command line option ‘-Wstrict-prototypes’ is valid for C/ObjC but not for C++ [enabled by default]
    In file included from src/errors.cpp:2:0:
    src/pyodbc.h:56:17: fatal error: sql.h: No such file or directory
     #include <sql.h>
                     ^
    compilation terminated.
    error: command 'x86_64-linux-gnu-gcc' failed with exit status 1
 
    ----------------------------------------
Command "/usr/bin/python3 -u -c "import setuptools, tokenize;__file__='/tmp/pip-build-uy211_p4/pyodbc/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('\r\n', '\n');f.close();exec(compile(code, __file__, 'exec'))" install --record /tmp/pip-2segjg5z-record/install-record.txt --single-version-externally-managed --compile" failed with error code 1 in /tmp/pip-build-uy211_p4/pyodbc/
 
cs



의존성과 관련하여 다른 프로그램을 사전 설치할 필요가 있습니다.


1. python-pip 를 설치합니다.

 : apt-get install unixodbc-dev

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
# apt-get install unixodbc-dev
Reading package lists... Done
Building dependency tree
Reading state information... Done
The following extra packages will be installed:
  libltdl-dev libodbc1 libtool odbcinst odbcinst1debian2 unixodbc
Suggested packages:
  libtool-doc libmyodbc odbc-postgresql tdsodbc unixodbc-bin gcj-jdk
The following NEW packages will be installed:
  libltdl-dev libodbc1 libtool odbcinst odbcinst1debian2 unixodbc unixodbc-dev
0 upgraded, 7 newly installed, 0 to remove and 2 not upgraded.
Need to get 804 kB of archives.
After this operation, 5,198 kB of additional disk space will be used.
Do you want to continue? [Y/n] Y
Get:1 http://archive.ubuntu.com/ubuntu/ trusty/main libodbc1 amd64 2.2.14p2-5ubuntu5 [175 kB]
Get:2 http://archive.ubuntu.com/ubuntu/ trusty/main odbcinst amd64 2.2.14p2-5ubuntu5 [12.6 kB]
Get:3 http://archive.ubuntu.com/ubuntu/ trusty/main odbcinst1debian2 amd64 2.2.14p2-5ubuntu5 [40.6 kB]
Get:4 http://archive.ubuntu.com/ubuntu/ trusty/main libltdl-dev amd64 2.4.2-1.7ubuntu1 [157 kB]
Get:5 http://archive.ubuntu.com/ubuntu/ trusty/main libtool amd64 2.4.2-1.7ubuntu1 [188 kB]
Get:6 http://archive.ubuntu.com/ubuntu/ trusty/main unixodbc amd64 2.2.14p2-5ubuntu5 [19.8 kB]
Get:7 http://archive.ubuntu.com/ubuntu/ trusty/main unixodbc-dev amd64 2.2.14p2-5ubuntu5 [211 kB]
Fetched 804 kB in 4s (188 kB/s)
Selecting previously unselected package libodbc1:amd64.
(Reading database ... 55073 files and directories currently installed.)
Preparing to unpack .../libodbc1_2.2.14p2-5ubuntu5_amd64.deb ...
Unpacking libodbc1:amd64 (2.2.14p2-5ubuntu5) ...
Selecting previously unselected package odbcinst.
Preparing to unpack .../odbcinst_2.2.14p2-5ubuntu5_amd64.deb ...
Unpacking odbcinst (2.2.14p2-5ubuntu5) ...
Selecting previously unselected package odbcinst1debian2:amd64.
Preparing to unpack .../odbcinst1debian2_2.2.14p2-5ubuntu5_amd64.deb ...
Unpacking odbcinst1debian2:amd64 (2.2.14p2-5ubuntu5) ...
Selecting previously unselected package libltdl-dev:amd64.
Preparing to unpack .../libltdl-dev_2.4.2-1.7ubuntu1_amd64.deb ...
Unpacking libltdl-dev:amd64 (2.4.2-1.7ubuntu1) ...
Selecting previously unselected package libtool.
Preparing to unpack .../libtool_2.4.2-1.7ubuntu1_amd64.deb ...
Unpacking libtool (2.4.2-1.7ubuntu1) ...
Selecting previously unselected package unixodbc.
Preparing to unpack .../unixodbc_2.2.14p2-5ubuntu5_amd64.deb ...
Unpacking unixodbc (2.2.14p2-5ubuntu5) ...
Selecting previously unselected package unixodbc-dev.
Preparing to unpack .../unixodbc-dev_2.2.14p2-5ubuntu5_amd64.deb ...
Unpacking unixodbc-dev (2.2.14p2-5ubuntu5) ...
Processing triggers for man-db (2.6.7.1-1ubuntu1) ...
Setting up libodbc1:amd64 (2.2.14p2-5ubuntu5) ...
Setting up libltdl-dev:amd64 (2.4.2-1.7ubuntu1) ...
Setting up libtool (2.4.2-1.7ubuntu1) ...
Setting up odbcinst1debian2:amd64 (2.2.14p2-5ubuntu5) ...
Setting up unixodbc (2.2.14p2-5ubuntu5) ...
Setting up unixodbc-dev (2.2.14p2-5ubuntu5) ...
Setting up odbcinst (2.2.14p2-5ubuntu5) ...
Processing triggers for libc-bin (2.19-0ubuntu6.6) ...
 
cs


2. python-pip 를 설치합니다.

 : apt-get install python-pip

1
2
3
4
5
6
7
# apt-get install python-pip
Reading package lists... Done
Building dependency tree
Reading state information... Done
python-pip is already the newest version.
0 upgraded, 0 newly installed, 0 to remove and 2 not upgraded.
 
cs



3. 다시 pyodbc 설치를 진행합니다.

 : pip install pyodbc

1
2
3
4
5
6
7
8
9
10
# pip install pyodbc
Collecting pyodbc
  Using cached pyodbc-4.0.22.tar.gz
Building wheels for collected packages: pyodbc
  Running setup.py bdist_wheel for pyodbc ... done
  Stored in directory: /root/.cache/pip/wheels/4f/ca/76/a2d9249e460278808e73f834a0312bb9747bb5b8800670cf80
Successfully built pyodbc
Installing collected packages: pyodbc
Successfully installed pyodbc-4.0.22
 
cs




1. 실행 창에서 cmd 창을 실행합니다.



* 실행 창 단축키는 "Ctrl + R" 와 같습니다.



2. cmd 창에서 다음과 같이 "pip install PyMySQL" 을 실행합니다.

1
2
3
4
5
6
7
C:\Users\Admin>pip install PyMySQL
Collecting PyMySQL
  Downloading PyMySQL-0.7.11-py2.py3-none-any.whl (78kB)
    100% |████████████████████████████████| 81kB 428kB/s
Installing collected packages: PyMySQL
Successfully installed PyMySQL-0.7.11
 
cs



3. python 에 접속합니다.

1
2
3
4
C:\Users\Admin>python
Python 3.6.2 (v3.6.2:5fd33b5, Jul  8 2017, 04:14:34) [MSC v.1900 32 bit (Intel)] on win32
Type "help", "copyright", "credits" or "license" for more information.
 
cs



4. pip install 을 통해 설치한 pymsql 을 import 합니다.

1
2
>>> import pymysql
 
cs



5. 접속 정보를 다음과 같이 입력하여 접속을 시도합니다.

1
2
>>> conn = pymysql.connect(host='192.168.11.123', port=3306, user='test', password='test', db='board', charset='utf8')
 
cs

* port 와 같은 경우 기본 포트 3306 일 경우에 생략 가능합니다.



6. 연결이 성공하였을 경우 아래와 같이 커서를 설정합니다.

1
2
>>> curs = conn.cursor()
 
cs



7. 간단한 질의문을 변수에 저장합니다.

1
2
>>> sql = "select * from board_pro"
 
cs



8. 질의문이 담긴 변수를 커서의 실행 메소드에 매개 변수로 전달합니다. 다음 라인에 바로 건수가 출력됩니다.

1
2
3
>>> curs.execute(sql)
7
 
cs



9. 커서로부터 모든 행을 가져와서 rows 변수에 저장합니다.

1
2
>>> rows = curs.fetchall()
 
cs



10. rows 변수에 담긴 값들을 출력합니다.

1
2
3
>>> print(rows)
((4, 'test first', 'test first', 'test first', datetime.datetime(2017, 11, 6, 2, 27, 23), 0), (5, 'test second', 'test second', 'test second', datetime.datetime(2017, 11, 6, 2, 27, 33), 0), (6, 'test third', 'test third', 'test third', datetime.datetime(2017, 11, 6, 2, 27, 41), 0), (7, 'test fourth', 'test fourth', 'test fourth', datetime.datetime(2017, 11, 6, 2, 28, 12), 0), (8, '??? ??', '??? ?????', '??', datetime.datetime(2017, 11, 9, 8, 10, 58), 12), (9, '??? ', '???', '??? ??', datetime.datetime(2017, 11, 9, 8, 13, 53), 1), (10, '??? ? ???....', '?? ??', 'test', datetime.datetime(2017, 11, 9, 8, 45, 38), 5))
 
cs

* 참고로 데이터베이스에서 조회한 결과는 다음과 같습니다.



11. 연결을 끊고 작업을 마무리합니다.

1
2
>>> conn.close()
 
cs




1
2
3
4
var curYear  = "2017";
var curMonth = "10";
var maxDay = new Date(new Date(curYear, curMonth, 1)-86400000).getDate();
 
cs


* 86400000ms 는 1일을 의미합니다.



OS Version: Windows 10

Node.js Version: node-v7.4.0-x64


1.

* http://nodejs.org/ 에서 해당 Node.js 를 다운 받습니다.

* v6.9.4 LTS : 대부분의 사용자에게 권장하는 버전.

* v7.4.0 Current : 최신 버전.


2.

*다운 받은 node-v7.4.0-x64.msi 를 실행하면 다음과 같은 화면 출력 시 Next 버튼을 눌러주세요.


3.

* 해당 체크 박스를 체크한 후에 Next 버튼을 클릭합니다.


4.

* Node.js 가 설치될 경로를 확인 후에 Next 버튼을 클릭합니다.


5.

* 설치할 프로그램에 대해서 트리 구조로 표시되고 있으며 필요에 맞게 선택 후 Next 버튼을 클릭합니다.


6.

* 설치를 진행하기 위해서 Install 버튼을 클릭합니다.


7.

* 해당 프로그램 설치 진행 시 화면입니다.


8.

* Finish 버튼을 클릭하여 설치가 마무리합니다. 이어서 Node.js 설치가 제대로 되었는지 확인을 진행하겠습니다.


9.

* Win + R 키를 누르면 위와 같이 실행 창이 나오는데 cmd 를 입력한 후에 확인 버튼을 클릭합니다.


10.

* 커맨드 창에 node -v 명령어를 입력하여 실행했을 때 위와 같이 해당 버전이 출력되면 이상 없이 설치되었다고 할 수 있습니다.


'Programming > Node.js' 카테고리의 다른 글

node-v10.12.0-x64 설치 및 환경 구축  (0) 2018.10.20
node.js 시작하기  (0) 2018.06.18

+ Recent posts