'php' 태그의 글 목록 :: 드라마 애니메이션 영화

'php'에 해당되는 글 2건

php에는 랜덤으로 숫자를 생성하는 함수로 rand()와  mt_rand()가 있습니다.


mt_rand는 메르센 트위스터 난수생성기(Mersenne Twister Random Number Generator)를 이용한 함수라고 합니다.


mt_rand사용 법은 2가지입니다.


1. mt_rand();

2. mt_rand(int $min, int $max);


1번은 파라미터 없이 사용하는 경우인데 이때에는 0부터 표현가능한 최대값 사이에서 랜덤한 숫자를 나타내줍니다.

2번은 최소값과 최대값 파라미터 사이에서 랜덤한 값을 보여줍니다.


사용법은 다음과 같습니다.


1
2
3
4
5
6
7
8
<?php
 
    $random_min = 0
    $random_max = 100;
    $random_number = mt_rand($random_min$random_max);
 
?>
 
cs


블로그 이미지

골드라이트

드라마 애니메이션을 중심으로 영화 생활정보 등도 소개합니다.

,

▶ 윤년 계산이 필요 없다 ???!!!!!

 

보통 달력을 만들거나 해당 달이 몇일까지 있는지 혹은 그해가 윤년이 있는지 등을 알기 위해서  윤년 계산을 하게 됩니다.


즉 윤년은 400 으로 나누어지는 (나머지가 0 인경우) 경우와 4 로 나누어지면서 100 으로 나누어지지 않는 경우입니다.


 이렇게 해서 윤년인 해의 2월은 29일까지 평년인 경우 28일로 정하고, 나머지 달은 1, 3, 5, 7, 8, 10, 12 월은 31일  4, 6, 9, 11 월은 30 일로 설정하게 됩니다.


쉬운 방법이지만, 뭔가 좀 이상하고, 불편하다는 느낌이 듭니다.

PHP 에서는 해당달의 총일자를 구하는 함수도 있습니다. 물론 ASP ??없지요..

    


▣ PHP 에서의 경우


1
2
3
4
5
6
7
8
9
<?php
       //첫요일과 총일자 숫자로 얻기
        $intTimeStamp = mktime(0,0,0,$nowMonth,1,$nowYear);
              // 해당달($nowMonth) 의 1일의 타임스탬프 얻기
        $intFirstDayNum = date(w,$intTimeStamp);           
             // 해당달($nowMonth) 의 요일을 숫자로 얻어오기
        $cntMonthDay = date(t,$intTimeStamp);               
            // 해당달($nowMonth) 의 총일자수
?>
cs


 ASP 에서는 그런 함수가 없어서 윤년 계산법을 이용해야 하는 불편이 있었습니다.

 하지만 달력을 만들면서, 편법?, 꽁수?, Tip 을 찾았습니다.


▣ ASP 에서의 경우


1
2
3
4
5
6
7
<%
''= 그 달의 첫날의 요일과 총일자 숫자로 가져오기
    intFirstDayNum = WeekDay(nowYear & "-" & nowMonth & "-01")   
             '''= 해당월(nowMonth) 1일의 요일을 숫자로 반환
    cntMonthDay = Day(DateSerial(nowYear, nowMonth + 11 - 1))   
             '''= 해당달(nowMonth)의 총일자수
%>
cs





◈ 여기서 핵심은 DateSerial() 함수입니다.

 

함수에 대한 설명은 다음과 같이 되어 있습니다.

        

Returns a Variant of subtype Date for a specified year, month, and day.  DateSerial(year, month, day)

        

특정한 - 즉 지정한 년,월,일에 해당하는 날짜형식에 맞는 값을 반환합니다.


예를 들면..


1
2
3
4
5
<%
    Dim MyDate1, MyDate2
    MyDate1 = DateSerial(197011' Returns January 1, 1970.
    MyDate2 = DateSerial(1990 - 108 - 21 - 1' Returns May 31, 1980.
%>
cs


 즉 MyDate1 은 그냥 1970년 1월 1일을 그대로 반환합니다. 별볼일 없죠?  하지만 MyDate2 는 1990에서 10을 빼서 1980년, 8월에서 2를 빼서 6월  여기서 중요한 1일에서 1을 뺐으니 0이 되어야 합니다.


그러면 숫자계산으로는 1980년 6월 0일이 되겠죠? 하지만 날짜??0일이 없습니다.

여기는 DateSerial 함수는 +, 혹는 - 를 단순히 숫자계산이 아닌  해당 년,월,일에서 몇년, 몇월, 몇일 다음, 또는 이전을 뜻합니다.


즉 1990 - 10 은 1990년 보다 10년 전 년도를 뜻합니다.

그러므로 1 - 1 은 1일의 하루 전날 즉 그 전달의 마지막 날짜를 뜻합니다.

최종적으로 보면 1980년 6월 1일의 하루 전날 = 1980년 5월 31일이 됩니다.


그래서 이번달의 총일자수를 얻으려면 다음달 1일에서 하루 전날을 구해보면 되겠죠?

결국 Day(DateSerial(nowYear, nowMonth + 1, 1 - 1))

이렇게 이번달 nowMonth 에 1을 더한 다음달 에서

1일의 하루 전날 즉 이번달의 마지막 날을 구합니다.


 몇월달인지 윤년인지, 평년인지 상관할 필요없습니다.

 이미 컴퓨터는 윤년인지 아닌지 알고 있으니까요.


 오히려 제 설명 때문에 복잡하고 이상하죠? 그러면 그냥 함수 사용법만 익히시면 됩니다.

블로그 이미지

골드라이트

드라마 애니메이션을 중심으로 영화 생활정보 등도 소개합니다.

,