상대 참조, 절대 참조 및 혼합 참조 간 전환

셀 참조는 기본적으로 상대적입니다. 

예를 들어, C2 셀에서 A2 셀을 참조하는 경우 실제로 왼쪽으로 두 열(C - A) 떨어진 같은 행(2)의 셀을 참조합니다. 상대 셀 참조가 들어 있는 수식은 한 셀에서 다른 셀로 복사할 때 변경됩니다.

예를 들어, C2 셀의 수식 =A2+B2를 D2 셀로 복사하는 경우 D2의 수식은 한 열 오른쪽으로 조정되어 =B2+C2가 됩니다. 이 예제에서 수식을 복사할 때 원래 셀 참조를 유지하려면 열(A 및 B)과 행(2) 앞에 달러 기호($)를 붙여 셀 참조를 절대 참조로 만들어야 합니다. 그런 다음 수식=$A$2+$B$2를 C2에서 D2로 복사하면 수식이 그대로 유지됩니다.

경우에 따라 열 또는 행 값 앞에 달러 기호를 붙여 셀 참조를 "혼합" 참조로 만들어 열 또는 행을 "잠글" 수도 있습니다(예: $A2 또는 B$3). 셀 참조의 유형을 변경하려면 다음을 수행합니다.

  1. 수식이 들어 있는 셀을 선택합니다.

  2. 수식 입력줄 단추 이미지 에서 변경할 참조를 선택합니다.

  3. F4 키를 눌러 참조 형식 간에 전환합니다.

    다음 표에서는 참조를 포함하는 수식이 아래쪽 두 셀과 오른쪽 두 셀에 복사될 때 참조 형식이 업데이트되는 방식을 약술합니다.

복사되는 수식

참조

변경 결과

A1에서 두 셀 아래 오른쪽으로 복사된 수식

$A$1(절대 열과 절대 행)

$A$1(절대 참조)

A$1(상대 열과 절대 행)

C$1(혼합 참조)

$A1(절대 열과 상대 행)

$A3(혼합 참조)

A1(상대 열과 상대 행)

C3(상대 참조)



<%
set xml = Server.CreateObject("Msxml2.ServerXMLHTTP.3.0")
xml.open "GET", url, false
xml.setRequestHeader "Content-Type", "application/x-www-form-urlencoded"
xml.send
res1 = xml.status
res = xml.responsetext
 
'한글 깨짐 방지
Set responseStrm = CreateObject("ADODB.Stream")
responseStrm.Open
responseStrm.Position = 0
responseStrm.Type = 1
responseStrm.Write xml.responseBody
responseStrm.Position = 0
responseStrm.Type = 2
responseStrm.Charset = "utf-8"
resultStr = responseStrm.ReadText
Response.Write resultStr  '불러온 내용을 뿌려주는 부분,뿌리기전에 값을 replace등오로 가공하여 필요한 부분만 취하면 됩니다.
responseStrm.close
Set responseStrm = Nothing
'한글 깨짐 방지

Set xml = Nothing
 
%>









출처: http://www.erel.kr/bbs/board.php?bo_table=study&sca=ASP%26ASP.NET

'프로그램 > ASP' 카테고리의 다른 글

날짜계산  (0) 2018.03.11
asp 함수모음  (0) 2018.03.11
ASP와 ASP.net 의 차이점  (0) 2018.02.26
DateDiff 라는 함수를 사용하면 간단히 알 수 있습니다.
 
<%
dim strDate
dim intDay,intMonth,intYear
strDate="2008년 2월 1일"
intDay= datediff("d",strDate,now)
intMonth= datediff("m",strDate,now)
intYear= datediff("yyyy",strDate,now)
Response.Write "년 경과 : " & intYear & "<br>"
Response.Write "월 경과 : " & intMonth & "<br>"
Response.Write "일 경과 : " & intDay & "<br>"
%>
 
위에서 "d", "m", "yyyy"와 같은 옵션들은 다음과 같은 것들이 있습니다.
-------------------------------



-------------------------------
만약 두 날짜 사이에 몇초의 간격이 있는지 구한다면..
DateDiff("s", date1, date2) 와 같이 사용하시면 됩니다.
 
도움 되시길 바라며 즐거운 하루 되세요.
설명
yyyy
연도
q
분기
m
y
일년 중 몇째 날
d
w
평일
ww
h
시간
n
s


'프로그램 > ASP' 카테고리의 다른 글

다른사이트의 정보를 내사이트에 연동하기  (0) 2018.03.11
asp 함수모음  (0) 2018.03.11
ASP와 ASP.net 의 차이점  (0) 2018.02.26
1. 대소문자의 구분
  asp 에서는 다른 언어와는 달리 대소문자의 구분이 없다. 그냥 단지 알아보기 쉽게 하기 위해서 대소문자를 사용하는 것이다.
  예) dim strname 는 Dim strName 과 같은 구문이다.

2. 변수 선언
- 변수나 배열의 변수 선언에는 dim 을 사용한다.
- Option Explicit 를 asp 맨 앞에 사용하여 변수를 꼭 선언하도록 하였으면 모든 변수는
   dim 으로 선언하여 사용하여야한다.
예) 변수 선언 : dim strName, strEmail
     배열 선언 : dim monthArry(11)
- Redim : 배열 크기의 재선언에 사용한다.
           redim 의 사용은 처음 배열 선언시에 배열의 크기를 정해 주지 않았을 때에만 가능하다.
- Preserve : 데이터를 저장한 채로 배열의 크기를 늘려준다. 즉, 기존의 들어가 있는 데이터는 그대로 아직 존재한다.
 

3. 구분자
- 구분자로는 :(콜론) 이 쓰인다.
- 구분자는 실행할 문장을 한줄단위로 구분짓는 역할을 한다.
예) dim strName : strName = "mshout77" : response.write "
strName = " & strName
 
 
4. 연결연산자
- &
- &가 문자열에 쓰이면 문장과 문장을 연결해서 한 문장으로 만들어준다.
- &가 변수에 쓰이면 변수의 값을 & 다음의 값과 이어준다.
- 예) dim strName, strFName, all
       strName = "77"
       strFName = "mshout"
       all = strName&strFName
      
       response.write all
       결과값은 mshout77 이라고 출력된다.
 
 
5. 주석
- ASP에서 주석처리에는 '(작은 따옴표) 가 쓰인다.
- 행에서 ' 다음의 내용은 주석처리되어 해석이 되지 않는다.
 

6. 함수
1) cdbl(문자열) - 문자열을 소수점이하까지도 출력(큰 숫자에 사용한다)

2) round(숫자,반올림할 위치) - 지정한 소수점 자리에서 반올림한 값을 리턴

3) asc(문자열) - 문자열에서 첫번째 문자에 대한 ansi 코드 번호를 리턴

4) chr(아스키코드번호) - 지정된 번호와 일치하는 ansi 문자로 구성된 문자열을 리턴

5) hex(숫자) - 숫자의 16진수값을 나탸내는 문자열을 리턴

6) fix(숫자) - 숫자의 정수(전체)부분을 리턴 / 음수일때 숫자보다 크거나 같은 첫번째 음의 정수 리턴

7) int(숫자) - 숫자의 정수(전체)부분을 리턴 / 음수일때 숫자보다 작거나 같은 첫번째 음의 정수 리턴

8) sgn(숫자) - 숫자의 부호를 나타내는 정수를 리턴

9) cdate(숫자) - 날짜 형식의 인자값 리턴( 예:cdate(36890) , cdate("2001년 12월 10일") )

10) Clng(숫자) - Long 형식의 문자열 리턴

11) Cstr(숫자) - String 형식의 문자열 리턴

12) Csng(숫자) - Single 형식의 문자열 리턴

13) formatcurrency(숫자) - 숫자를 화폐형식으로 전환

14) formatdatetime(date,1) - date 함수의 표시형태를 바꿈
     - formatdatetime(date,2)
     - formatdatetime(date,3)

15) formatpercent(숫자) - 숫자를 백분율로 표시

16) strConv - 지정한대로 문자를 변환, strConv(문자열,conversion [,LCID])
    conversion 에 가능한 값
     - vbUpperCase 1 문자열을 대문자로 변환
     - vbLowerCase 2 문자열을 소문자로 변환
     - vbPropercase 3 문자열 단어의 첫글자를 대문자로 변환
     - vbWide 4 1바이트문자를 2바이트 문자로 변환
     - vbNarrow 5 2바이트문자를 1바이트문자로 변환
     - vbUnicode 6 시스템의 기본 코드 페이지를 사용하여 문자열을 unicode 로 변환
     - vbFromUnicode 128 unicode 문자열을 시스템의 기본 코드 페이지로 변환

17) Randomize - 난수 발생기를 초기화
    - 난수값 = Int((상한값 - 하한값) + 1) * Rnd + 하한값
    - 예로 1부터 100사이의 난수를 가져오려면, 난수값 = Int(100 - 1 + 1) * Rnd + 1

18) Atn() - 숫자의 아크 탄젠트 값을 리턴

19) Cos() - 각도의 코사인값을 리턴

20) Exp() - e(자연 로그의 밑)의 인자만큼의 제곱을 리턴

21) Log() - 숫자의 자연로그를 리턴

22) Sin() - 각도의 사인값을 리턴

23) Tan() - 각도의 탄젠트값을 리턴
24) InStr("문자열","찾을 문자") - 문자열의 위치 반환

25) InStrRev("문자열","찾을 문자") - 문자열의 위치를 뒤에서 부터 검색해서 반환

26) Lcase("문자열") - 문자열을 소문자로

27) Ucase("문자열") - 문자열을 대문자로
28) Len("문자열") -문자열의 길이 반환
29) Left("문자열",잘라낼 갯수) - 문자열을 왼쪽에서 지정한 갯수만큼 잘라냄

30) Right("문자열",잘라낼 갯수) - 문자열을 오른쪽에서 지정한 갯수만큼 잘라냄
31) Mid("문자열",시작위치,뽑아낼 갯수) - 문자열의 어느 부위를 뽑아냄

32) Yrim("문자열") - 문자열의 양쪽 공백을 제거

33) Ltrim("문자열") - 문자열의 왼쪽 공백을 제거

34) Rtrim("문자열") - 문자열의 오른쪽 공백을 제거
35) Split("문자열","분리자") - 분리자를 기준으로 문자열을 나눔
36) StrReverse("문자열") - 문자열을 뒤집음
37) IsArray() - 변수가 배열인지의 여부를 나타내는 Boolean 값을 리턴

38) IsDate() - 날짜로 변환될 수 있는지의 여부를 나타내는 Boolean 값을 리턴

39) IsEmpty() - 변수가 초기화 될 수 있는지의 여부를 나타내는 Boolean 값을 리턴

40) IsNull() - 유효한 데이터를 포함하고 있는지의 여부를 리턴

41) IsNumeric() - 숫자로 평가될 수 있는지의 여부를 리턴

42) IsObject() - 유효한 ActiveX혹은 OLE 자동화 개체를 참조하는지의 여부를 리턴

43) Vartype() - 변수의 하위 형식을 나타내는 숫자를 리턴한다.

44) now - 시스템의 시간과 날짜

45) date - 시스템의 날짜

46) time - 시스템의 시간

47) year(now) - 현재의 년도

48) month(now) - 현재의 월
 
49) day(now) - 현재의 일

50) weekday(now) - 현재의 요일
 
51) hour(now) - 현재의 시

52) minute(now) - 현재의 분

53) second(now) - 현재의 초

54) DateAdd - 지정된 날짜에 시간을 추가하거나 뺀 새로운 날짜를 반환
   사용법) DateAdd(interval, number, date) 
           - interval : 필수적인 인수로 interval을 추가한 날짜를 나타내는 문자식
                     yyyy 년, q 분기, m 월, y 일(일년 기준), d 일, w 요일, ww 주(일년 기준), h 시, n 분, s 초

           - number : 필수적인 인수로 추가할 간격 수의 수식
                     수식에서 양수는 미래의 날짜, 음수는 과거의 날짜이다.

           - date : 필수적인 인수로 interval을 추가한 날짜를 나타내는 Variant 또는 리터럴

   예) DateAdd("m",3,Date)  <-- 현재의 날짜에서 3개월을 더함
       DateAdd("m",-3,Date)  <-- 현재의 날짜에서 3개월을 뺌

55) DateDiff - 주어지는 두 날짜의 간격을 반환
   사용법) DateDiff(interval, date1, date2 [,firstdayofweek[, firstweekofyear]]) 
           - interval : 필수적인 인수로 날짜1과 날짜2 사이의 차이를 계산하는 데 사용할 interval의 문자식
                     yyyy 년, q 분기, m 월, y 일(일년 기준), d 일, w 요일, ww 주(일년 기준), h 시, n 분, s 초                

           - date1, date2 : 필수적인 인수로 날짜식에서 계산에 사용할 두 날짜

           - firstdayofweek : 선택적인 인수로 요일을 지정하는 상수로 지정하지 않으면 일요일로 간주
                            vbUseSystem 0 NLS(National Language Support) API 설정 사용 
                            vbSunday 1 일요일(기본값) 
                            vbMonday 2 월요일 
                            vbTuesday 3 화요일 
                            vbWednesday 4 수요일 
                            vbThursday 5 목요일 
                            vbFriday 6 금요일 
                            vbSaturday 7 토요일
           - firstweekofyear : 선택적인 인수로 연도를 기준으로 한 첫째 주를 지정하는 상수
                            지정하지 않으면 1월 1일을 포함하는 주를 첫째 주로 간주한다. 
                            vbUseSystem 0 NLS(National Language Support) API 설정 사용 
                            vbFirstJan1 1 1월 1일을 포함하는 주에서 시작(기본값) 
                            vbFirstFourDays 2 새해의 처음 4일을 포함하는 주에서 시작 
                            vbFirstFullWeek 3 새해의 처음 한 주일(7일)을 포함하는 주에서 시작
  
   예) DateDiff("h", "2001년 12월 30일", Date) 
       DateDiff("n", "2001년 12월 30일 09:30:00", now) 
       DateDiff("s", "2001년 12월 30일 09:30:00", now)
56) DatePart - 주어진 날짜의 지정된 부분을 반환한다. 
   사용법) DatePart(interval, date[, firstdayofweek[, firstweekofyear]]) 
           - interval : 필수적인 인수로 반환할 시간 간격의 문자식이다.
                     yyyy 년, q 분기, m 월, y 일(일년 기준), d 일, w 요일, ww 주(일년 기준), h 시, n 분, s 초

           - date : 필수적인 인수로 계산할 날짜식
 
           - firstdayof week : 선택적인 인수로 요일을 지정하는 상수로서 지정하지 않으면 일요일로 간주
                            vbUseSystem 0 NLS(National Language Support) API 설정 사용 
                            vbSunday 1 일요일(기본값) 
                            vbMonday 2 월요일 
                            vbTuesday 3 화요일 
                            vbWednesday 4 수요일 
                            vbThursday 5 목요일 
                            vbFriday 6 금요일 
                            vbSaturday 7 토요일

           - firstweekofyear : 선택적인 인수로 연도를 기준으로 한 첫째 주를 지정하는 상수
                            지정하지 않으면 1월 1일을 포함하는 주를 첫째 주로 간주한다. 
                            vbUseSystem 0 NLS(National Language Support) API 설정 사용 
                            vbFirstJan1 1 1월 1일을 포함하는 주에서 시작(기본값) 
                            vbFirstFourDays 2 새해의 처음 4일을 포함하는 주에서 시작 
                            vbFirstFullWeek 3 새해의 처음 한 주일(7일)을 포함하는 주에서 시작
   예) DatePart("q", now)
57) DateSerial - 지정된 년, 월, 일의 Date 하위 형식인 Variant를 반환한다. 
               즉, 임의의 숫자를 입력받아 날짜 형식으로 반환하는 함수이다. 
   사용법) DateSerial(year, month, day) 
           year : 100에서 9999까지의 수 또는 수식 
           month : 모든 수식 
           day : 모든 수식 
   예) DateSerial(2001, 12, 25)
58) DateValue - Date 하위 형식의 Variant를 반환한다. 
   사용법) DateValue(date)
   예) DateValue("2000년 12월 25일")


'프로그램 > ASP' 카테고리의 다른 글

다른사이트의 정보를 내사이트에 연동하기  (0) 2018.03.11
날짜계산  (0) 2018.03.11
ASP와 ASP.net 의 차이점  (0) 2018.02.26

ASP와 ASP.net 의 차이점은 무엇인가요?

kdkim0521 2008.06.19 21:04

ASP와 ASP.net의 차이점은 무엇인가요?

그리고 ASP를 배움에 있어서

초급정도의 수준을 넘어서 중급이상을 배우고자 할 때

추천할만한 책 있나요?

그리고 취업을 할 때 대부분 경력자를 뽑는데

자기 혼자서 실무처럼 해볼 수 있는 방법은 없나요?

 

 

답변 부탁드립니다.

  

re: ASP와 ASP.net 의 차이점은 무엇인가요? 90.7%

2008.06.20 14:40

질문자인사 감사합니다 많은 도움이 되었어요

ASP는 최초의 웹 스크립트 언어입니다. Microsoft 에서 Visual Basic 을 기반으로 VBScript 를 만들고 이 스크립트를 사용하여 웹 페이지의 동적인 기능을 수행하도록 만들었습니다. 이것이 CGI가 주로 사용되던 웹 개발 환경에 상당한 반향을 불러와서 이후 PHP, JSP 등도 생겨나게 됩니다.

ASP는 최초 발생 이후 버전업을 하면서 발전을 해왔지만 스크립트 언어 자체의 한계로 생산성, 유지보수 등에 문제를 드러내게 됩니다. 하나의 ASP 페이지에 디자인과 제어 코드들이 섞여 있는 부분은 소형 웹페이지 개발에 손쉽다는 장점이 있지만, 중대형 규모의 사이트에는 적합하지 않은 구조가 됩니다..  또한 ASP 이후에 생긴 객체지향을 지원하는 서버 스크립트들과 비교되면서 ASP는 안좋은 구조의 서버 스크립트로 인식되게 됩니다.

ASP에 있는 문제들을 해결하기 위해서 기존의 VBScript 사용을 배제한 객체지향적이면서 디자인과 코드가 분리된 MVC 패턴과 유사한 형태의 개발 환경이 만들어지는데 이것을 ASP.NET 이라고 부릅니다.

ASP.NET은 Microsoft의 닷넷(.NET) 시스템 위에서 동작하는 서버 스크립트를 의미합니다.
위에 설명한 ASP의 문제점 대부분을 해소한 것이 ASP.NET 입니다. ASP.NET을 능숙하게 개발하기 위해서는 객체지향에 대한 기본적인 이해가 필요하고, 디자인 페이지와 코드 페이지가 분리된 MVC 스타일의 개발 환경에 대한 이해가 필요합니다.

ASP 개발을 위해서 익혀야 되는 서버 기술은 VBScript 이지만, ASP.NET 개발을 위해서는 C#, Visual Basic, C++ 등 닷넷을 지원하는 언어를 익혀야 합니다. 참고로 C# 이 .NET 기반 언어 중 에서 최신 기술이 가장 빠르게 업데이트 되는 언어이고 실무에서도 가장 많이 쓰이고 있습니다. 만약 ASP.NET을 처음 배우신다면 처음부터 C# 으로 입문하시는 것을 권해드립니다.

ASP 언어가 나온지 오래되어 좋은 책들이 상당수 절판된 상태입니다. 혹시 구하실 수 있다면 taeyo's Advanced ASP to be Professional (정보문화사)가 괜찮습니다. 최근에도 ASP 서적이 종종 나오고 있으니 이것들도 알아보시면 괜찮을듯 합니다.

업체에서 경력자를 채용할때 혼자 실무처럼 해본 프로젝트는 경력으로 인정하지 않습니다. 신입 개발자 채용을 하는 곳을 찾아서 입사하신 후에 경력을 쌓으시는 것이 기본적인 순서입니다. 실무처럼 해본 프로젝트를 아주 약간이나마 인정받을 수 있는 경우가 신입 지원을 했을때 입니다. 어짜피 경력이 없는 사람들 중에 선발하게 되므로 혼자서라도 뭔가 프로젝트를 해봤다면 평가에 긍정적인 영향을 받게 될 겁니다.

혹시 이것이 여의치 않다면 프리랜서로 작은 프로젝트부터 진행해보시는 것이 차선책입니다. 보통 기업체에서 진행하는 프로젝트에 투입되는 프리랜서는 상당한 경력이 있어야 하므로 무경력자가 처음부터 이런 프로젝트를 맡을 수는 없습니다. 작은 웹사이트 구축이나 유지보수 등을 구해서 해보시는 것이 좋을 듯 합니다. 

그래도 처음부터 혼자 작업을 하는 것은 신입 채용을 하는 회사에 입사하시는 것 보다 나을 수가 없습니다. 어느 정도 체계가 잡혀 있는 시스템을 배우게 되는 것과 그런 시스템 없이 혼자 주먹구구로 만들어가는 것은 결국 분명한 차이를 드러내게 됩니다

'프로그램 > ASP' 카테고리의 다른 글

다른사이트의 정보를 내사이트에 연동하기  (0) 2018.03.11
날짜계산  (0) 2018.03.11
asp 함수모음  (0) 2018.03.11
델파이에 컴포넌트를 추가할때는 2가지 방법이 있다.
dpk(팩키지파일)와 pas(소스파일)가 있는 경우와 dpk없이 pas만 있는 경우가 설치가 있다.

dpk와 pas가 존재하는 컴포넌트 추가하기

1.file/open을 클릭하여 dpk파일을 엽니다.
2.팩키지관리자창이 뜨면 install을 클릭하여 컴포넌트를 추가합니다.
3.컴포넌트의 라이브러리를 연결해야 합니다.
4.tools/environment options을 클릭합니다.
5.library탭을 클릭한후 library path의 ..을 클릭하여 새창이 뜨면 거기서 ..을 눌러 컴포넌트
라이브러리 경로를 선택후 ok을 클릭합니다.
6.마지막으로 add을 누르고 ok을 클릭합니다.

dpk는 없는데 pas가 존재하는 컴포넌트 추가하기

1.file/new/other에서 package를 클릭합니다.
2.팩키지관리자창이 뜨면 add를 클릭한후 unit file name을 클릭하여 컴포넌트에 필요한
모든 pas파일을 선택합니다.
3.install을 클릭하여 컴포넌트를 추가합니다.
4.file/save as을 클릭하여 dpk파일을 저장합니다.
※ 나중에 또다시 팩키지 파일을 설치시에 편하게 설치하기 위해서입니다.
※ component/install component 메뉴를 이용해서 컴포넌트를 추가할수 있지만 좀 어렵다.

설치된 컴포넌트 삭제하기

1.component/install package를 클릭합니다.
2.design packages에서 삭제하고 싶은 컴포넌트를 선택합니다.
(컴포넌트를 선택후 components를 눌러 컴포넌트 확인)
3.remove를 클릭하여 삭제합니다.
(add는 bpl파일을 추가시킬때 사용합니다.-볼랜드팩키지라이브러리)
4.tools/environment options을 클릭합니다.
5.library탭을 클릭한후 library path에서 삭제한 컴포넌트의 path를 선택후 delete합니다.

설치된 컴포넌트가 어떤 컴포넌트 페이지에 등록되어 있는지 모를때

1.설치하려는 dpk파일을 열어 팩키지 관리자에서 pas파일을 열어서 아래의 부분을 참고한다.

procedure Register;
begin
  RegisterComponents('Samples', [TMacProgress]);
end;

위의 내용에서 보듯이 'Samples' 컴포넌트 페이지에 컴포넌트가 추가된다.

팔레트 페이지에 특정 페이지 추가하기

팔레트페이지에서 오른쪽 마우스를 누른후 properties을 누른다.
add버튼을 클릭한후 적당한 팔레트페이지명을 입력하고 확인버튼을 누릅니다.
델파이6까지는 비어있는 팔레트페이지도 보였으나 델파이7부터는 비어있는
팔레트페이지는 화면에서 보이지 않습니다.
※ hide는 화면에 팔레트 페이지를 보이지 않게 하지만 한번 hide하면 보이게 하기 힘드므로 사용하지 않는다.

Activex 컨트롤을 컴포넌트로 추가하기

1. component/import activex control을 클릭합니다.
2. 상단 리스트에서 등록된 activex을 선택후 install을 클릭하며 컴포넌트가 추가됩니다.

3. 상단 리스트에서 등록되지 않은 activex는 add버튼을 클릭후 추가하고 싶은 ocx 파일을 선택한후install을 클릭합니다.


윈도우를 이용하다보면 종종 설치된 업데이트를 확인할 일이 있다.


예를 들면,  윈도우즈 업데이트(KB2724197)는 부팅시 chkdsk 반복과 관련이 있는데 (ID 46, volmgr 관련), 이 문제를 해결하려면 먼저 KB2724197 의 설치여부 확인이 필요하다.


물론, 제어판>프로그램>설치된 업데이트 보기
를 통해 전체 목록을 확인할 수는 있다.

하지만 엄청난 개수의 목록에서 눈으로 KB2724197을 찾기란 쉬운일이 아니다.


이런 때 설치된 업데이트 목록을 텍스트 파일로 받을 수 있다면 ?

노트패드 혹은 즐겨쓰는 편집기에서 검색으로 쉽게 찾을 것이다. (노트패드라면 Ctrl-F)


이 용도로 간단하게 이용가능한 것이 wmic 이다. (Windows Management Instrumentation Command-line Tool. 윈도우 XP이상 기본 명령이며 별도 설치가 필요없다.)

wmic에는 다양한 기능이 있지만 글에서는 업데이트 찾기 내용만 알아본다.


1. 도스창을 연다. (도스창 여는 법은 아래 포스팅에도 있으니 생략한다. 귀차니즘에 자비를 ^^)

2013/04/25 - [IT서비스, 팁, 앱, 게임등] - 윈도우7 한번에 화면 끄기 (화면보호기 즉시 실행 + 단축키) 눈보호, 전기절약~


2. wmic 명령을 실행한다.


c:\Users\aaa> wmic qfe list



3. 아래 형태로 업데이트 내역이 출력된다.

Caption                                        CSName     Description      FixComments  HotFixID   InstallDate  InstalledBy          InstalledOn  Name  ServicePackInEffect  Status  
http://go.microsoft.com/fwlink/?LinkId=161784  YourHost  Update                        KB971033                NT AUTHORITY\SYSTEM  5/20/2013                                       
http://support.microsoft.com/?kbid=2305420     YourHost  Security Update               KB2305420               YourHost\aaa      5/16/2013                                       
http://support.microsoft.com/?kbid=2393802     YourHost  Security Update               KB2393802               YourHost\aaa      5/15/2013                                       
http://support.microsoft.com/?kbid=2425227     YourHost  Security Update               KB2425227               YourHost\aaa      5/15/2013                                      

설치된 윈도우 업데이트들의 아이디 KBxxxx 을 확인할 수 있다.



* 파일로 옮겨서 확인하고 싶다면, 아래처럼 파일로 리다이렉트 (결과 출력을 aaa.txt 파일로) 한 후, 
노트패드로 확인한다.

c:\Users\aaa> wmic qfe list >  aaa.txt

c:\Users\aaa> notepad  aaa.txt




확실히, 이런 용도로는 명령행이 짱이다~ ^^


※ 본문 내용은 윈도우7 에서 실행하였다. 윈도우 XP이상부터 적용 가능하다.



출처: http://2daddies.tistory.com/entry/윈도우-업데이트-한번에-확인하기-KBxxxxxx [2 Daddies (His Daddy 와 Her Daddy의 팀블로그)]

델파이는 VCL(visual compoment library)이라고 불리는 하나의 객체 지향적인 구조를

사용한다. VCL이라는 말은 Visual Component Library, 즉 볼 수 있는 컴퍼넌트의

집합이라고 할 수 있는데, 컴퍼넌트는 VCL의 계보 중에서  TComponent와 그 자손으로

이어진 계층을 말합니다.

그런데 VCL를 살펴보면 컴퍼넌트 중 에서 볼 수 없는 즉 Visual하지 않는 컴퍼넌트도

많다는 것을 알 수 있습니다.더욱이 컴퍼넌트가 아닌 오브젝트도 많이 볼 수 있습니다.

(TStrings나 TCanvas 같은) 따라서 엄밀하게 VCL은 틀린 말입니다.

그럼에도 불구하고, 델파이에서 왜 VCL이라고 이름을 붙였을까? 그것은 아마도 이들

컴퍼넌트가 가장 핵심적인 역할을 담당하고 있기 때문일 것입니다.

우리가 어플리케이션을 만들어 실행시키면 볼 수 있는 것의 대부분이 이들 컴퍼넌트입니다.

 

컴퍼넌트 정의

 

기술적으로 컴퍼넌트는  VCL 계보에서 TComponent 클래스의 모든 자손 오브젝트를

나타냅니다. 즉 TComponent에서 파생된 모든 오브젝트를 컴퍼넌트라 부릅니다.

그리고 VCL 계보에서 TBitmap, TStringList와 같이 컴퍼넌트에 속하지 않는 것들은

오브젝트라고 부릅니다. 

개념적으로 컴퍼넌트는 그 용어 자체에서 의미하는 바와 같이 부품을 나타냅니다.

즉 어풀리케이션을 만들기 위해 사용하는 부품을 의미합니다. 자동차가 각종 차동차

부품으로 이루어지듯이, 델파이 어플리케이션도 각종 부품(컴퍼넌트)로 이루어지는

것입니다.

물론 자동차나 어플리케이션을 부품(컴퍼넌트)를 조립(사용)하지 않고 만들수도 있습니다.

그러나 그러한 경우 생산성이나 효율성은 무척이나 나빠지게 될 것입니다.

VCL에는 컴퍼넌트가 아닌 다른 많은 오브젝트가 있습니다. 그럼에도 불구하고

컴퍼넌트를 중요시하는 것은 , 설계시에는 이 컴퍼넌트를 사용하기 때문입니다.

즉 설계시에 사용할 수 있는 컴퍼넌트이고, 따라서 컴퍼넌트가 시각적 프로그래밍의

핵심이라 할 수 있습니다.

컴퍼넌트가 아닌 다른 오브젝트는 내부에서 컴퍼넌트를 위해 이용하는 도구이거나

아니면 델파이에서 사용하는 오브젝트들입니다.

 

컴포넌트 종류

 

visual component

시각적으로 표현 가능하며 내부적으로 연산이 가능한 컴포넌트

non-visual component

시각적으로 표현 불가능하며 내부적으로 연산이 가능한 컴포넌트

 

컴포넌트의 기본 속성(컴포넌트에 거의 공통적으로 들어가는 속성이다.)
 
Name
컴포넌트의 이름을 가리킨다. Name 은 반드시 영문이나 밑줄 시작해야 하며 한글, 특수문자 등은 들어갈 수 없다.
Caption
컴포넌트의 제목을 나타내준다. 한글이나 특수문자 등도 모두 쓰일 수 있다.
Alignment
컴포넌트 내부의 문자열이 정렬되는 방식에 대한 속성이다. 디폴트값은 taLeftJustify 이다.
taLeftJustify : 문자열이 컴포넌트의 좌측에 정렬된다.
taCenter : 문자열이 컴포넌트의 중앙에 정렬된다.
taRightJustify : 문자열이 컴포넌트의 우측에 정렬된다.
Autosize
컴포넌트의 내용에 맞게 크기를 자동으로 조정할지를 결정
AutoSelect
사용자가 Edit component나 Memo 컴포넌트로 tab할 때 문자가 자동으로 전체선택될지를 조정

BorderStyle
컴포넌트의 border 형을 결정
CharCase
영문자를 표현하는 방법(입력하는대로 또는 무조건 대문자 또는 무조건 소문자)
Color
컴포넌트의 배경 색을 정한다.
Ctl3D
Control이 3차원인지 2차원인 모양인지 결정
Cursor
컴포넌트가 차지한 영역에서 나타나는 마우스 포인터의 이미지를 결정
DragCursor
끌어당긴 개체를 컴포넌트위에 올려 놓을 때 나타나는 마우스 포인터의 이미지 결정
DragMode
컴포넌트의 끌고 놓는 동작을 결정
Enabled
컴포넌트의 기능을 일시적으로 활성, 또는 비 활성화 시킬 수 있다. 디폴트값은 True이다.
Font
컴포넌트에 나타나는 문자의 글꼴, 색상,크기 등의 여러 속성을 지정한다.
Hint
OnHint event발생시 나타나는 문자열을 결정 (마우스 커서가 컴포넌트나 메뉴 항목에 있을 때 나타남)

Tag
일반적으로 Tag Property는 볼랜드사에서 프로그래머를 위해서 임의로 만들어 놓은 Property 이며 temp변수로도 사용할 수도 있습니다.
LongInt의 형을 가지고 있으며 LongInt로서 할 수 있는 모든 것을 할 수도 있습니다.
일반적인 문자열, 정수, 실수 외에 델파이에서 지원되는 객체나 구조체, 또는 메모리까지도 
Tag에 넣어서 사용할수가 있습니다.

Height, width, left, top
Height : 컴포넌트의 크기 조절
width : 컴포넌트의 높이 조절
left : 컴포넌트의 맨 왼쪽 모서리의 위치 조절
top : 컴포넌트의 맨 위쪽 모서리의 위치 조절
HideSelection
개체가 Focus를 잃을 때 선택되어 있던 문자를 반전된 채로 남겨둘지를 결정
MaxLength
Edit 컴포넌트나 Memo 컴포넌트에 입력할 수 있는 최대 문자수를 결정. Zeor(0)은 제한이 없음을 의미
PasswordChar
Password를 입력할 때 Edit 컴포넌트나 Memo 컴포넌트가 어떤 특수문자를 나타낼지를 결정

ParentColor
 다음과 같이 컴포넌트의 색정보를 어디서 찾을지를 결정:
◆ 만약 값이 True면, parent component의 Color property를 사용
◆ 만약 값이 False면, 컴포넌트 자신의 Color property를 사용.
ParentCtl3D
 다음과 같이 Component의 3차원 모양을 어디서 찾을 지를 결정:
◆ 만약 값이 True면, parent component의 three-dimensional property를 사용
◆ 만약 값이 False면, component자신의 three-dimensional property를 사용

ParentFont
 다음과 같은 컴포넌트의 font 정보를 어디서 찾을지를 결정:
◆ 만약 값이 True면, parent component의 font property를 사용
◆ 만약 값이 False면, component자신의 font property를 사용

ParentShowHint
 다음과 같이 컴포넌트의 힌트를 어디서 찾을지 결정:
◆ 만약 값이 True면, parent component의 ShowHint property를 사용
◆ 만약 값이 False면, component자신의 ShowHint property를 사용
ReadOnly
실행시 read-only 컴포넌트를 만들어 사용자가 field나 dataset값을 변경할 수 없도록 함
ShowHint
 힌트가 사용될지 아닐지를 결정:
◆ 만약 값이 True면 힌트사용
◆ 만약 값이 False면, 힌트 사용 안함
Text
컴포넌트나 다른개체에 나타나는 문자열을 기술합니다.

 

TabOrder

 

Tab 키를 눌렀을 때 컴포넌트의 taborder대로 실행이나 입력준비 상태가 변경됨

 

※ taborder 속성값이 0 인 컴포넌트는 폼 생성시 자동으로 포커스를 얻습니다.

※ 아래 소스가 keydown 이벤트에 있다면 엔터 입력시 taborder 값이 0부터 큰값으로

포커스가 이동하게 됩니다.

if key = vk_return then

begin

    //# 엔터 입력시 taborder 값의 순서대로 포커스 이동됨

    SendMessage(self.Handle, WM_NEXTDLGCTL, 0, 0);

end;

 

TabStop

 컴포넌트에 tab를 사용할 지를 결정

※ taborder 값이 동작하려면 tabsop 속성값이 true로 되어 있어야함

 

Tab
 컴포넌트의 property로서 정수값을 저장하도록 함.주의: 델파이에 의해 직접 사용되지는 않지만 응용프로그램의 특별한 목적으로 사용할 수 있다.
Visible
프로그램 실행 시 컴포넌트를 보이게 할 것인지를 지정한다. 디폴트 값은 True이다.

 

컴포넌트의 기본 이벤트(컴포넌트에 거의 공통적으로 들어가는 이벤트이다.)

 

델파이의 이벤트는 콜백함수입니다.

콜백함수란 프로그래머가 그 함수의 사용을 명령해 주는 것이 아닌 이벤트, 메시지 등을

받았을 때 자동으로 실행되는 함수를 말한다.

 

OnChange 
개체나 컴포넌트에 지정된 값이 변화될 할 때 발생 
OnClick 

컴포넌트를 클릭할 때 발생 
OnDblClick 
컴포넌트를 두번 클릭할 때 발생

OnDragDrop 
끌어당긴 개체를 놓을 때 발생 
OnDragOver 

컴포넌트위로 개체를 끌 때 발생
OnEndDrag 
개체를 끄는 것을 끝낼 때 발생
OnEnter 
컴포넌트가 활성화될때만 발생 

컴포넌트로 포커스가 들어왔을때 발생
※ 자바스크립트의 onfocus 이벤트 핸들러와 같은 역할을 합니다.

 

OnExit

focus가 다른 컴포넌트로 움직일 때 발생

 

OnKeyDown

key를 눌렀을 때 발생. 특수키(ctrl, alt, shift, tab, enter, backspace,F1~F12 등등)에 반응함

ex1)

if key = 13 then

ShowMessage(‘d’);

 

※ keydown이벤트는 키값을 숫자로 리턴합니다.

※ keydown 이벤트에서 리턴하는 key 값은 10진수 정수입니다.

※ 위의 이벤트가 발생하려면 해당 폼의 Keypreview 속성이 True여야 한다.

※ F1부터 F12의 키값은 112부터 123입니다.

※ OnKeyUp 이벤트 발생하기 전에 발생한다.

※ 10진수 13은 아스키코드에서 엔터입니다.

 

ex0)

if Key = VK_RETURN then

ShowMessage(‘leejunsik’);

※ 엔터키값의 상수는 VK_RETURN 입니다.

 

예제1)

//# ctrl+v 키보드 입력시 발생

if (ssCtrl in Shift) and (Key in [86, 118]) then

begin

 ShowMessage(edit1.Text);

end;

 

예제2)

//# ctrl+c 키보드 입력시 발생

if (ssCtrl in Shift) and (Key in [67, 99]) then

begin

 ShowMessage(edit1.Text);

end;

 

예제3)

//# ctrl+v 키보드 입력시 발생

If (Shift = [ssCtrl]) and (Key = 67) then

begin

 ShowMessage(‘test’);

end;

 

OnKeyPress 이벤트

key를 눌렀을 때 발생. 특수키(ctrl, alt, shift, tab, enter, backspace,F1~F12 등등)에 반응안함

참고 : #13 – 엔터키 #9 – 탭키

ex)

if key = #13 then ShowMessage(‘d’);

※ keypress이벤트는 키값을 문자로 리턴합니다.)

※ 위의 이벤트가 발생하려면 해당 폼의 Keypreview 속성이 True여야 한다.

※ OnKeyUp 이벤트 발생하기 전에 발생한다.

 

StrCopy(@Key, pChar(UpperCase(Key)));

※ 영문자 입력시 자동으로 대문자로 변환됨

소스설명

char형 key를 받아서 UpperCase 함수로 대문자로 변환하여 string 형으로 리턴후

pChar함수에 의해 string형의 끝에 널제로를 붙히고 @Key로 복사한다.

char형 key앞에 @를 붙히면 pChar형으로 변환되며 strCopy는 pChar형 변수를 pChar형

변수로 복사할때 사용하는 함수이다.

 

예제1

//# 키보드 ctrl+c 입력시 발생

if Key = #3 then

begin

   ShowMessage(‘test’);

end;

 

예제2

//# 키보드 ctrl+v 입력시 발생

if Key = #22 then

begin

   ShowMessage(‘test’);

end;

 

OnKeyUp 이벤트

누른 Key를 놓았을 때 발생, 키를 누른후에 발생

※ OnKeyDown와 OnKeyPress 이벤트핸들러가 발생한후 발생하는 이벤트

 

금액 변경 예제

procedure TFw_212.wEdit2KeyUp(Sender: TObject; var Key: Word;
  Shift: TShiftState);
begin
  //# "거래후 카드 잔액" 변동 #//
  if (realgrid1.RowCount <> 0) and (wedit2.Text <> ”) then begin
    with realgrid1 do begin
      wedit7.Text := inttostr(strtoint(co_chardelete(Cells[9,row].AsString,’,’)) – strtoint(wedit2.text));

      //# 마이너스 정수 처리 #//
      if strtoint(wedit7.Text) < 0 then begin
        wedit2.Text := co_chardelete(Cells[9,row].AsString,’,’);
        wedit7.Text := ‘0’;
        exit;
      end;
    end;
    //# 0030, 00050 같은 정수에서 맨앞에 필요없는 0 없애기 #//
    wedit2.Text := inttostr(strtoint(wedit2.Text));
  end;
end;

 
procedure TFw_212.wEdit7KeyUp(Sender: TObject; var Key: Word;
  Shift: TShiftState);
begin
  //# "거래금액" 변동 #//
  if (realgrid1.RowCount <> 0) and (wedit7.Text <> ”) then begin//# 공백체크 없을시 에러난다. #//
    with realgrid1 do begin
      wedit2.Text := inttostr(strtoint(co_chardelete(Cells[9,row].AsString,’,’)) – strtoint(wedit7.text));

      //# 마이너스 정수 처리 #//
      if strtoint(wedit2.Text) < 0 then begin
        wedit2.Text := ‘0’;
        wedit7.Text := co_chardelete(Cells[9,row].AsString,’,’);
        exit;
      end;
    end;
    //# 0030, 00050 같은 정수에서 맨앞에 필요없는 0 없애기 #//
    wedit7.Text := inttostr(strtoint(wedit7.Text));
  end;
end;

—————————————————————————–

procedure TFw_d00.edit3KeyUp(Sender: TObject; var Key: Word;
  Shift: TShiftState);
begin

  //# 0부터 99까지만 입력가능하게
  if ((Sender as TEdit).Text <> ”) then
  begin
    if (strtoint((Sender as TEdit).Text) > 99) then
    begin
      (Sender as TEdit).Text := ’99’;
    end;
    //# 앞에 0없애기
    (Sender as TEdit).Text := inttostr(strtoint((Sender as TEdit).Text));
  end
  else
  begin
    (Sender as TEdit).Text := ‘0’;
  end;

end;

 

OnMouseDown 
컴포넌트상에서 마우스 버튼을 눌렀을 때 발생 

 
OnMouseMove 
컴포넌트상에서 마우스를 움직일 때 발생 

 
OnMouseUp 
컴포넌트상에서 눌려있던 마우스 버튼을 놓았을 때 발생 

 
OnStartDrag 
끌어당기기를 시작할 때 발생

 
Form(폼) 속성/메소드
 
comment
 
메인폼 객채로써 프로그램 시작시 자동으로 만들어진다.
 
property
 
ActiveControl-form생성시 초기 포커스를 둘 컴포넌트를 지정
 
※ 사용예제(아래 Edit1에 포커스를 주는 두 명령은 같은 역할을 합니다.)

ActiveControl := Edit1;

Edit1.SetFocus;

※ 사용예제2

ActiveControl := RealGrid1;

 

AutoSize-폼에 놓여진 컴포넌트에 맞게 폼의 가로/세로 크기가 딱 맞추어진다.(권장)
PopupMenu-팝업메뉴 컴퍼넌트를 현재 Form에 적용한다.
AutoScroll-프로그램 실행시 폼의 사이즈 조절 유무를 설정한다.(True-조절 가능)
clientwidth – 테두리선을 제외하고 사용가능한 원도우 가로 크기를 설정한다.
clientheight – 캡션바와 테두리선을 제외하고 사용가능한 원도우 세로 크기를 설정한다.

width – 폼의 전체 가로 크기를 지정, 테두리선의 크기를 합친 크기이다.
height – 폼의 전체 세로 크기를 지정, 캡션바와 테두리선의 크기를 합친 크기이다.
 
clientwidth, clientheight 사용시점
윈도2000에서 개발한 프로그램이 XP(테마사용)에서는 크기가 변경되어 폼에 스크롤바가 생기는 경우가 있다. 이때는 OnCreate시에 ClientWidth와 ClientHeight속성을 강제로 지정하면 된다.
 
Cursor – 해당 폼안에서 컴포넌트를 제외한 곳에서의 커서를 설정한다.
crDefault – 기본적인 커서 모양
crHourGlass – 일반 처리시 커서 모양
crSQLWait – SQL 처리시 커서 모양

* 커서 변경 소스
Screen.Cursor := crDefault; //# 커서 모양이 기본 커서 모양으로 변경
Screen.Cursor := crHourGlass; //# 커서 모양이 모래시계 모양으로 변경

Screen.Cursor := crSQLWait; //# 커서 모양이 모래시계+SQL문자열 모양으로 변경

Keypreview – 이 속성이 True로 설정되면, 폼 위에 컨트롤이 있더라도 키보드와 관련된 이벤트가 발생하는 경우, 폼의 이벤트를 먼저 발생한 후에 컨트롤 이벤트를 발생한다.
HelpFile – 도움말 파일을 지정한다.
FormStyle-폼스타일을 정한다.
fsMDIChild-mid폼 자식으로 만듬
fsMDIForm-mdi폼 부모로 만듬
fsNormal(평범한 폼)
fsStayOnTop(항상 상단에 뜨는 폼)
※ 다른 프로그램과 같이 화면에 떠있더라도 fsStayOnTop를 적용한 프로그램은 항상 상단에 뜬다.
 
BorderStyle-폼의외곽선을 바꾼다.
bsNone(타이틀바가 없음)-제목표시줄과 외곽선이 안보이며 배경만 나온다.
※ 프로그램 시작폼에 많이 사용
bsToolWindow(사이즈조절불가능,타이틀바보임,조금만종료만표시,아이콘안보임)
bsSizeToolWin(사이즈조절가능,타이틀바보임,조금만종료만표시,아이콘안보임)
bsSizeAble(사이즈조절가능,타이틀바보임,종료/최대화/최소화표시,아이콘보임)-default
bsSingle(사이즈조절불가능,타이틀바보임,종료/최대화/최소화표시,아이콘보임)
bsDialog(사이즈조절불가능,타이블바보임,큰종료만표시,아이콘안보임)
※ 혹시 bsSingle설정이면서 최대화/최소화 표시가 안나오게 하려면 BorderIcons속성에서 최대화와 최소화 출력 여부를 체크하면됩니다.
(BorderIcons속성은 BorderStyle속성에 영향을 주지 않습니다.)
 
Icon – 제목표시줄의 아이콘과 실행파일의 아이콘을 설정합니다.

 

WindowState – 해당 폼이 화면에 출력될때의 형태지정

wsMaximized : 폼이 열릴 때 자동으로 최대화됨

wsMinimized : 폼이 생성될때 자동으로 최소화됨

wsNormal : 폼이 생성될때 최대화도 아닌 최소화도 아닌 일반상태로 출력됨

 

Position – 해당 폼이 화면에 출력될때 위치를 설정함

poMainFormCenter : 메인폼 화면의 가로세로의 정가운데에 출력됨

poDesktopCenter : 듀얼 모니터 화면를 합쳐서 가로세로의 정가운데에 출력됨

poScreenCenter : 듀얼 모니터 화면중 메인 화면의 가로세로의 정가운데에 출력됨

※ 듀얼모니터 환경에서 개발후 싱글모니터에 배포시 팝업창의 top, left 속성값이 마이너스

일때 화면에 안보일수도 있다. 이때는 정상적으로 폼이 보이기 위해 poMainFormCenter 값을

사용해야 한다.

poDesigned : 디자인모드시 위치하고 있는 그위치에 출력됨

※ WindowState 속성값이 wsMaximized, wsMinimized 이면 Position 속성값은 크게 의미가

없다.

 

Method

close-해당 품을 종료한다.

 

Standard 페이지

 

MainMenu Component

property

Checked-해당 메뉴를 체크한다.

Enabled-해당메뉴를 비활성화 한다.

Short Cut-바로가는 키 설정

※ Short Cut은 메뉴항목을 빠르게 선택하고자 키보드를 이용하여 조합키로서 해당

메뉴항목을 선택하는 방법이다. 물론 단축키와 유사하지만 Short Cut은 해당 메뉴가

떠있지 않는 상태에서 사용할 수 있지만 단축키는 메뉴가 떠 있을 때 사용하는 방법이다.

 

Label 컴포넌트

property

alignment-출력할 문자열을 정렬한다.

※ 한글이 제대로 출력안될때는 해당 Form의 폰트를 한글폰트로 바꾸면 됩니다.

(굴림체 추천)

transparent-라벨의 배경색을 투명하게 합니다.

※ shape component위에 label component을 놓고 transparents 속성을 true로 하면 이쁘게

디자인이 됩니다.(류님이 알려주셨음^^)

※ 이쁜 영문 폰트 설정 법 : 글꼴 – Verdana, 글꼴스타일 – 보통, 크기 – 20

 

StaticText 컴포넌트

comment

StaticText 과 Label 사이의 차이점은, StaticText 은 TWinControl 로부터 상속받아 윈도우

핸들을 가지고 있다는 점입니다.

※ 이쁜 영문 폰트 설정 법 : 글꼴 – Verdana, 글꼴스타일 – 보통, 크기 – 20

 

CheckBox 컴포넌트

comment

체크박스(CheckBox)가 선택할 수 있는 것은 ‘예’(체크가 된 상태)과 ‘아니오’(체크가 되어있지

않는 상태)이다.

property

Checked-체크박스(CheckBox)안에 ‘V’표시가 나타나게 할것인지를 결정한다.

Enabled-체크박스를 직접체크 가능하게 할지 안할지를 결정(true-직접체크 가능)

※ checkbox 의 Enabled 속성이 false 일때는 직접 체크와 이벤트도 실행 안되지만 대입

및 참조는 가능하다.

※ checkbox 의 Enabled 속성이 false 일때 setFoucs 함수를 사용하면 에러가 난다.

 

RadioButton 컴포넌트

Comment

라디오버튼은 여러개의 라디오버튼에서 오직 하나만 선택이 가능한 컴포넌입니다.
폼안에서는 모든 RadioButton이 자동으로 한그룹이며 다른 그룹으로 하려면 RadioGroup,GroupBox등을 이용해서 사용합니다.

Property

Checked-라디오박스(RadioButton)의 선택을 나타나게 할것인지를 결정한다.
※ 라디오버튼을 따로 그룹화하려면 2가지 방법이 있다.
1. 라디오그룹컴포넌트 사용하기
2. 패널컴포넌트안에 라디오버튼 넣어서 하나의 그룹으로 인식시키기

 

RadioGroup 컴포넌트

 

Comment

라디오그룹(Radio Group)컴포넌트는 그룹박스(Group Box)안에 라디오버튼(Radio Button)을

포함시켜 다른 라디오버튼(Radio Button)과 구분하여 사용할 수 있는 컴포넌트이다.

Property

Checked – 라디오버튼(Radio Button)이 선택되어있는지 여부를 나타낸다.

Columns – 한줄에 나타낼 수 있는 항목의 수를 지정

Items – 항목의 목록을 나타낸다.

ItemIndex – 기본 선택될 항목의 순서값을 나타낸다.(0 이 맨처음)

※ ItemIndex 속성의 리턴 데이타형은 정수형이다.

Method

radiogroup1.items.count-라디오버튼의 갯수

RadioGroup1.Items.Strings[radiogroup1.ItemIndex]-선택한 제목의 문자열 출

RadioGroup1.ItemIndex – 현재 선택된 항목의 순서값을 나타낸다.(0 부터 시작)

Etc

라디오그룹의 순서값으로 순서값에 해당하는 문자열 출력하기

RadioGroup1.Items.Strings[RadioGroup1.ItemIndex];

— 순서값에 해당하는 문자열이 출력됨

RadioGroup1.Items.Strings[1];

— 2번째 항목의 문자열이 출력됨

※ Strings 속성의 인수형은 정수이다.

 

Edit 컴포넌트

Comment

한줄로 입력을 받을 사용합니다.

Property

AutoSize – Edit 컴포넌트의 세로길이가 Font 속성에서 설정한 글자크기의 세로크기로

자동으로 조절된다.

※ TRUE – 자동 조절, 가로크기는 조절안됨

passwordchar-edit컴포넌트에 입력되는 형식을 지정합니다.

#0-입력되는 문자가 그대로 출력됩니다.

#-입력되는 문자가 #로 출력됩니다.

※ #가 아니라 다른 문자를 쓴다면 해당 문자로 출력이 가능함

BorderStyle-edit박스의 테두리선을 선택한다.

Ctrl3D-텍스트 박스를 3차원혹은 2차원 형태로 나타낸다.

ShowHint-팁을 보여줄지 여부

MaxLength-입력크기를 제한한다.

(3 – 3바이트 크기만 입력가능, 10 – 10바이트 크기만 입력가능)

※ 0 입력시 입력크기에 재한이 없음

AutoSelect – 프로그램을 실행시 제일 처음 Edit 컴포넌트에 포커스가 갈때 자동으로 전체

선택되어 질지 아닐지를 설정한다.(TRUE-자동 전체 선택)

Method

 

CanFocus 설명

해당 컴포넌트에 포커스가 가능한지 불가능한지 체크함

사용예제

//# 해당 컴포넌트가 화면에 보이는 상태라면 포커스명령 실행

if Edit1.CanFocus then

begin

  Edit1.SetFocus;

end;

※ CanFocus 명령없이 화면에 보이지 않는 컴포넌트에 setfocus를 주게되면 아래의

에러 메시지가 뜨게 된다.

Cannot focus a disabled or invisible window.

 

focus-입력부분으로 커서가 이동한다.

TIP1

Enabled속성이 false인상태의 Edit 컴포넌트로 SetFocus메소드를 사용했을때 아래의

에러가 납니다. ex) wEdit1.SetFocus;

Cannot focus a disabled or invisible window.

하지만

ReadOnly속성이 false인상태의 Edit 컴포넌트로 SetFocus메소드를 사용할때는

잘작동합니다.

 

TIP2
※ Edt 컴포넌트의 Enabled,ReadOnly 속성이 false 일때는 직접 입력은 안되지만 대입 및 참조는 가능하다.
 
주의1
SelectAll 메소드는 Edit 컴포넌트의 문자열의 전체 선택하는 메소드이다.
근데 이 메소드는 onClick에 사용하면 동작하지만 onEnter에 사용하면 동작하지 않습니다.
포커스를 얻을때 SelectAll 메소드가 동작하는 효과를 얻으려면 RealGrid 패키지의 wEdit 컴포넌트를 사용하면 됩니다.(델6 에서 테스트)

 

 

Memo컴포넌트

comment

2줄 이상 입력받을때 사용합니다.

property

maxlength – 입력 문자수를 제한함

※ 테이블의 크기가 100바이트라면 maxlength 속성값도 100을 주면 된다.

 

Lines-입력상자안에 내용을 입력합니다.
visible-메모컴포넌트를 보일지 여부(false-보임)
align-정렬을 합니다.(altop-상단에붙음,alclient-상하단에붙음)
ReadOnly-읽기만 가능하게 한다.
scrollbard-좌우 스크롤 표시 유무
ssboth(가로세로스크롤바)
ssVertical(세로스크롤바)
ssnone(스크롤바없음)

method
clear-입력상자안에 내용을 모두 지웁니다.
lines-add-입력상자안에 내용의 끝부터 줄단위로 추가합니다.
lines-insert-입력상자안에 원하는 칸에 내용을 줄단위로 추가합니다.
text=입력상자안에 새로 내용을 추가합니다.(글자가 있었다면 자지워지고 새롭게 입력된다.)
LoadFromFile(file)-파일내용을 메모장안에 뿌려준다.

※ 메모 컴포넌트는 각 라인별로 폰트 속성을 다르게 주는것이 불가능합니다.

 

keydown 이벤트에 사용하는 ctrl+a 단축키 클릭시 전체문자역 선택되게

If (Shift = [ssCtrl]) and (Key = 65) then

begin

   (Sender as TMemo).SelectAll;

end;

 

Panel 컴포넌트

 

Comment

특정 모양으로 그룹을 지을수있는 컴포넌트이다.

 

Property

BorderWidth-화면에는 출력되지 않고 panel의 여백을 크기를 지정합니다.

align-상/하/좌/우/전체/사용자정의로 정렬을 시킵니다.

bevelouter-외곽선을 튀어나오게 할것인지 들어가게 할것인지 결정

byraised(외곽선을 튀어나오게 함)

bylowered(외곽선을 들어가게 함)

bynone(외곽선을 안보이게 함)

bevelinner-외곽선을 들어가지도 않고 나오지도 않은 2줄 구분선으로 출력

bsnone(아무 효과도 안준다)

bsrowered(2줄 구분선으로 출력)

 

※ 자주 사용하는 구분선 설정

 

구분선이 들어간 효과의 경우

bevelinner-bvRaised

bevelouter-bvLowered

구분선을 안보이게 하는 경우

bevelinner-bvNone

bevelouter-bvNone

 

※ 항목명으로도 많이 사용되어 진다.

 

Combobox컴포넌트

 

Comment

아이템을 콤보박스형태로 보여줍니다.

 

Property

text-초기 문자열을 지정합니다.

items-리스트 목록을 입력합니다.

ItemIndex-리스트 목록처음이 0부터 1씩 증가되는 아이템 순서 값

style-콤보박스 형태를 지정합니다.

csDropDown(드롭다운형태이며 수동입력 가능함)

csDropDownList(드롭다운형태이며 수동입력 불가능)

 

Method

text-현재 선택되어져 있는 값을 출력(읽기용)

ItemIndex-현재 선태된 리스트순서값을 숫자값으로 입력하여 바꿈(0부터시작)

items.IndexOf-해당 문자열이 있는 리스트 순서값을 알아낸다.

Items.Strings-리스트순서값을 이용해 해당 문자열을 출력(읽기용)

items.insert-리스트목록을 추가합니다.(추가위치를 지정가능)

items.add-리스트목록을 추가합니다.(추가위치지정불가능,무조건 맨뒤부터)

Items.CommaText – 콤마 단위로 문자열을 넣으면 쉽게 리스트목록에 추가할수 있다.

※ CommaText 사용후에는 반드시 ItemIndex 으로 초기값을 준다.



[데브기어] RAD Studio IDE에서 Help 다운로드


RAD Studio IDE에서 Help 다운로드 방법에 대해 안내 드립니다.

RAD Studio를 실행하시면 메뉴 중 Tools > Manage Platforms.. 가 있습니다.

Manage Platofrms 창을 띄어 Additionals 부분에

Help를 체크하시어 설치해보시기 바랍니다.

Help 외에도 Manage Platforms에서는 다양한 기능들을 추가 설치하실 수 있습니다.

델파이의 제어문에 있어서 두 줄이상일 경우는 begin과 end를 사용한다.
C에서의 { }에 해당한다.
델파이에서 세미콜론(;)을 사용하는데 있어서 주의해야 될 점은 세미콜론은 항상 문장의 끝을 나타내지만은 않는다. 세미콜론은 문장을 구분하는 한가지 방법이다. 
문장을 구분하는 방법에는 end나 else도 있다.

goto문도 있지만 goto문을 사용하면 프로그램을 이해하기 힘들어짐으로 그다지 사용되지 않는다.

■ 조건문 if

if문의 일반형식

if 식
  then 문1
  else 문2

이다 문1, 문2는 한줄이나 두줄이상은 begin ... end로 묶일 수 있다.
if문에서 주의해야되는 것은 세미콜론 말고도 else나 end가 문장을 구분하게된다.

if nA > 10 then
  nB := 10;
else
  nB := 20;

C를 짜던 사람이라면 위 소서를 일반적으로 생각하면 문제가 없지만, 델파이에서는 문자게 생긴다.
델파이에서는   nB := 10;에서 if문이 끝나게 된다.
델파이에서의 소스는 아래와 같이 써야된다.

if nA > 10 then
  nB := 10
else
  nB := 20;

begin ... end로 묶인 경우는 아래 소스와 같이 else 위의 end에는 세미콜론을 붙여서는 안된다.

if nA > 10 then
begin
  nB := 10;
  nC := 11;
end
else
begin
  nB := 20;
  nC := 22;
end;

그리고 아래의 소스에서 nC := 11 뒤에 세미콜론이 붙지않아도 문제가 된지않는다. 
이것은 end가 문을 구분하는 것으로 인식하기 때문에 세미콜론이 반드시 필요하지 않다.

if nA > 10 then
begin
  nB := 10;
  nC := 11
end

■ 조건문 case

case문은 복수의 선택을 할때 필요한 문을 실행할 수 있다.
(C에서의 switch문에 해당한다.)

사용예

  case StrToInt(Edit1.Text) of
    3 :
      begin
        Label1.Caption := '3';
      end;
    4 :
      begin
        Label1.Caption := '4';
      end;
    else
      begin
        Label1.Caption := 'XX';
      end;
  end;

■ 반복문 while

while문은 루프의 처음에서 조건이 오고 조건이 성립할 때 반복하는 문이다.
(C에서의 while문에 해당)

사용예

ni := 0;
while ni < 10 do
begin
  AA[i] := 0;
  ni := ni + 1;
end;

■ 반복문 repeat until

repeat until문은 루프의 마지막에서 조건이 오고 조건이 성립할 때 까지 반복하는 문이다.
(C에서의 do while문과 비슷하지만 조금 틀리다.)

사용예

  ni := 0;
  repeat
    AA[ni] := 0;
    ni := ni + 1;
  until ni > 10;

■ 반복문 for

for문은 인덱스가 되는 값을 1씩 증가시키거나 감소시켜가며 반복하는 문이다.
(C의 for보다 유연성이 떨어짐)

  for ni := 0 to 9 do
  begin
    AA[ni] := ni;
  end;

인덱스를 감소시킬 때는 to 대신 downto를 써야된다.

  for ni := 9 downto 0 do
  begin
    AA[ni] := ni;
  end;

+ Recent posts