from_camel_case, to_camel_case

· 14년 전 · 730
표기법이 달라 같은 엔티티 참조가 어려울때, 한쪽의 표기법을 변경하는 방법
자바나 자바스크립트 변수명 또는 XML의 node, attribute name이 camel 을 쓰고,
DB Column이 underscore(_) 를 쓰죠.
( db 컬럼과 xml 의 node명을 상호 참조할경우 아래와 같이 변환해서 쓰면 좋습니다.
xml을 파싱해서 db에 넣는다던지, db를 조회해서 xml을 만든다던지..
)
 
 
<?php
  /**
   * Translates a camel case string into a string with underscores (e.g. firstName -> first_name)
   * @param    string   $str    String in camel case format
   * @return    string            $str Translated into underscore format
   */
  function from_camel_case($str) {
    $str[0] = strtolower($str[0]);
    $func = create_function('$c', 'return "_" . strtolower($c[1]);');
    return preg_replace_callback('/([A-Z])/', $func, $str);
  }
 
  /**
   * Translates a string with underscores into camel case (e.g. first_name -> firstName)
   * @param    string   $str                     String in underscore format
   * @param    bool     $capitalise_first_char   If true, capitalise the first char in $str
   * @return   string                              $str translated into camel caps
   */
  function to_camel_case($str, $capitalise_first_char = false) {
    if($capitalise_first_char) {
      $str[0] = strtoupper($str[0]);
    }
    $func = create_function('$c', 'return strtoupper($c[1]);');
    return preg_replace_callback('/_([a-z])/', $func, $str);
  }

$test1 =   "MODIFY_DATE";
$test2 =   "modifyDate";
$result1 = to_camel_case(strtolower($test1));
$result2 = strtoupper(from_camel_case($test2));
echo "$test1 => $result1 <br>";
echo "$test2 => $result2 <br>";
?>
output:
MODIFY_DATE => modifyDate
modifyDate => MODIFY_DATE
|
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
14년 전 조회 1,469
14년 전 조회 4,555
14년 전 조회 1,429
14년 전 조회 1,199
14년 전 조회 710
14년 전 조회 942
14년 전 조회 753
14년 전 조회 628
14년 전 조회 702
14년 전 조회 700
14년 전 조회 645
14년 전 조회 1,523
14년 전 조회 823
14년 전 조회 694
14년 전 조회 644
14년 전 조회 715
14년 전 조회 1,007
14년 전 조회 908
14년 전 조회 1,502
14년 전 조회 1,118
14년 전 조회 3,584
14년 전 조회 800
14년 전 조회 1,353
14년 전 조회 1,103
14년 전 조회 2,834
14년 전 조회 2,442
14년 전 조회 646
14년 전 조회 1,687
14년 전 조회 667
14년 전 조회 2,456
14년 전 조회 2,004
14년 전 조회 613
14년 전 조회 5,708
14년 전 조회 962
14년 전 조회 1,480
14년 전 조회 1,298
14년 전 조회 1,325
14년 전 조회 1,219
14년 전 조회 1,219
14년 전 조회 1,035
14년 전 조회 1,399
14년 전 조회 1,791
14년 전 조회 808
14년 전 조회 1,188
14년 전 조회 2,221
14년 전 조회 2,064
14년 전 조회 1,034
14년 전 조회 1,506
14년 전 조회 4,014
14년 전 조회 731
14년 전 조회 2,728
14년 전 조회 1,494
14년 전 조회 1,946
14년 전 조회 1,154
14년 전 조회 916
14년 전 조회 935
14년 전 조회 1,067
14년 전 조회 1,156
14년 전 조회 2,034
14년 전 조회 3,273
14년 전 조회 2,318
14년 전 조회 1,035
14년 전 조회 1,633
14년 전 조회 1,899
14년 전 조회 685
14년 전 조회 1,925
14년 전 조회 3,162
14년 전 조회 1,836
14년 전 조회 2,773
14년 전 조회 4,082
14년 전 조회 4,124
14년 전 조회 2,528
14년 전 조회 952
14년 전 조회 1,262
14년 전 조회 4,082
14년 전 조회 2,402
14년 전 조회 1,553
14년 전 조회 3,929
14년 전 조회 2,596
14년 전 조회 673
14년 전 조회 2,593
14년 전 조회 723
14년 전 조회 959
14년 전 조회 1,807
14년 전 조회 1,427
14년 전 조회 1,677
14년 전 조회 1,238
14년 전 조회 2,246
14년 전 조회 908
14년 전 조회 923
14년 전 조회 749
14년 전 조회 1,559
14년 전 조회 1,180
14년 전 조회 895
14년 전 조회 5,421
14년 전 조회 2,023
14년 전 조회 1,268
14년 전 조회 753
14년 전 조회 9,551
14년 전 조회 1,680