from_camel_case, to_camel_case

· 14년 전 · 1584
표기법이 달라 같은 엔티티 참조가 어려울때, 한쪽의 표기법을 변경하는 방법
자바나 자바스크립트 변수명 또는 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년 전 조회 2,279
14년 전 조회 5,380
14년 전 조회 2,253
14년 전 조회 2,037
14년 전 조회 1,522
14년 전 조회 1,768
14년 전 조회 1,587
14년 전 조회 1,454
14년 전 조회 1,557
14년 전 조회 1,525
14년 전 조회 1,493
14년 전 조회 2,331
14년 전 조회 1,670
14년 전 조회 1,547
14년 전 조회 1,470
14년 전 조회 1,553
14년 전 조회 1,853
14년 전 조회 1,767
14년 전 조회 2,362
14년 전 조회 1,950
14년 전 조회 4,420
14년 전 조회 1,664
14년 전 조회 2,218
14년 전 조회 1,942
14년 전 조회 3,675
14년 전 조회 3,304
14년 전 조회 1,459
14년 전 조회 2,528
14년 전 조회 1,496
14년 전 조회 3,309
14년 전 조회 2,865
14년 전 조회 1,457
14년 전 조회 6,577
14년 전 조회 1,825
14년 전 조회 2,372
14년 전 조회 2,148
14년 전 조회 2,065
14년 전 조회 2,063
14년 전 조회 2,072
14년 전 조회 1,907
14년 전 조회 2,258
14년 전 조회 2,635
14년 전 조회 1,661
14년 전 조회 2,058
14년 전 조회 3,064
14년 전 조회 2,915
14년 전 조회 1,903
14년 전 조회 2,372
14년 전 조회 4,867
14년 전 조회 1,585
14년 전 조회 3,580
14년 전 조회 2,322
14년 전 조회 2,791
14년 전 조회 2,003
14년 전 조회 1,774
14년 전 조회 1,767
14년 전 조회 1,906
14년 전 조회 1,986
14년 전 조회 2,874
14년 전 조회 4,099
14년 전 조회 3,171
14년 전 조회 1,895
14년 전 조회 2,473
14년 전 조회 2,718
14년 전 조회 1,533
14년 전 조회 2,792
14년 전 조회 4,019
14년 전 조회 2,667
14년 전 조회 3,617
14년 전 조회 4,843
14년 전 조회 4,992
14년 전 조회 3,382
14년 전 조회 1,803
14년 전 조회 2,133
14년 전 조회 4,919
14년 전 조회 3,228
14년 전 조회 2,393
14년 전 조회 4,790
14년 전 조회 3,434
14년 전 조회 1,538
14년 전 조회 3,432
14년 전 조회 1,570
14년 전 조회 1,820
14년 전 조회 2,675
14년 전 조회 2,303
14년 전 조회 2,540
14년 전 조회 2,072
14년 전 조회 3,090
14년 전 조회 1,742
14년 전 조회 1,762
14년 전 조회 1,597
14년 전 조회 2,398
14년 전 조회 2,016
14년 전 조회 1,720
14년 전 조회 6,275
14년 전 조회 2,863
14년 전 조회 2,119
14년 전 조회 1,619
14년 전 조회 1만
14년 전 조회 2,513