from_camel_case, to_camel_case

· 14년 전 · 843
표기법이 달라 같은 엔티티 참조가 어려울때, 한쪽의 표기법을 변경하는 방법
자바나 자바스크립트 변수명 또는 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,543
14년 전 조회 4,593
14년 전 조회 1,509
14년 전 조회 1,287
14년 전 조회 781
14년 전 조회 1,012
14년 전 조회 800
14년 전 조회 690
14년 전 조회 772
14년 전 조회 784
14년 전 조회 727
14년 전 조회 1,591
14년 전 조회 911
14년 전 조회 754
14년 전 조회 712
14년 전 조회 784
14년 전 조회 1,089
14년 전 조회 980
14년 전 조회 1,623
14년 전 조회 1,195
14년 전 조회 3,643
14년 전 조회 873
14년 전 조회 1,470
14년 전 조회 1,166
14년 전 조회 2,952
14년 전 조회 2,555
14년 전 조회 737
14년 전 조회 1,752
14년 전 조회 754
14년 전 조회 2,502
14년 전 조회 2,104
14년 전 조회 683
14년 전 조회 5,820
14년 전 조회 1,049
14년 전 조회 1,607
14년 전 조회 1,395
14년 전 조회 1,379
14년 전 조회 1,301
14년 전 조회 1,300
14년 전 조회 1,113
14년 전 조회 1,464
14년 전 조회 1,878
14년 전 조회 898
14년 전 조회 1,272
14년 전 조회 2,287
14년 전 조회 2,138
14년 전 조회 1,105
14년 전 조회 1,618
14년 전 조회 4,123
14년 전 조회 844
14년 전 조회 2,837
14년 전 조회 1,608
14년 전 조회 2,014
14년 전 조회 1,219
14년 전 조회 998
14년 전 조회 989
14년 전 조회 1,128
14년 전 조회 1,201
14년 전 조회 2,099
14년 전 조회 3,369
14년 전 조회 2,415
14년 전 조회 1,105
14년 전 조회 1,702
14년 전 조회 1,975
14년 전 조회 756
14년 전 조회 2,019
14년 전 조회 3,244
14년 전 조회 1,902
14년 전 조회 2,848
14년 전 조회 4,153
14년 전 조회 4,201
14년 전 조회 2,596
14년 전 조회 1,056
14년 전 조회 1,322
14년 전 조회 4,156
14년 전 조회 2,496
14년 전 조회 1,640
14년 전 조회 4,005
14년 전 조회 2,666
14년 전 조회 740
14년 전 조회 2,665
14년 전 조회 788
14년 전 조회 1,009
14년 전 조회 1,884
14년 전 조회 1,509
14년 전 조회 1,763
14년 전 조회 1,296
14년 전 조회 2,354
14년 전 조회 980
14년 전 조회 976
14년 전 조회 826
14년 전 조회 1,630
14년 전 조회 1,243
14년 전 조회 982
14년 전 조회 5,531
14년 전 조회 2,126
14년 전 조회 1,385
14년 전 조회 827
14년 전 조회 9,624
14년 전 조회 1,744