from_camel_case, to_camel_case

· 14년 전 · 735
표기법이 달라 같은 엔티티 참조가 어려울때, 한쪽의 표기법을 변경하는 방법
자바나 자바스크립트 변수명 또는 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,471
14년 전 조회 4,560
14년 전 조회 1,429
14년 전 조회 1,205
14년 전 조회 711
14년 전 조회 946
14년 전 조회 754
14년 전 조회 632
14년 전 조회 707
14년 전 조회 702
14년 전 조회 649
14년 전 조회 1,525
14년 전 조회 825
14년 전 조회 694
14년 전 조회 647
14년 전 조회 717
14년 전 조회 1,009
14년 전 조회 909
14년 전 조회 1,502
14년 전 조회 1,122
14년 전 조회 3,586
14년 전 조회 802
14년 전 조회 1,355
14년 전 조회 1,104
14년 전 조회 2,836
14년 전 조회 2,442
14년 전 조회 647
14년 전 조회 1,688
14년 전 조회 669
14년 전 조회 2,458
14년 전 조회 2,004
14년 전 조회 615
14년 전 조회 5,709
14년 전 조회 962
14년 전 조회 1,483
14년 전 조회 1,299
14년 전 조회 1,328
14년 전 조회 1,221
14년 전 조회 1,219
14년 전 조회 1,036
14년 전 조회 1,402
14년 전 조회 1,792
14년 전 조회 814
14년 전 조회 1,191
14년 전 조회 2,223
14년 전 조회 2,067
14년 전 조회 1,036
14년 전 조회 1,509
14년 전 조회 4,014
14년 전 조회 736
14년 전 조회 2,731
14년 전 조회 1,496
14년 전 조회 1,948
14년 전 조회 1,157
14년 전 조회 917
14년 전 조회 936
14년 전 조회 1,067
14년 전 조회 1,159
14년 전 조회 2,038
14년 전 조회 3,278
14년 전 조회 2,321
14년 전 조회 1,038
14년 전 조회 1,636
14년 전 조회 1,901
14년 전 조회 686
14년 전 조회 1,927
14년 전 조회 3,162
14년 전 조회 1,838
14년 전 조회 2,774
14년 전 조회 4,085
14년 전 조회 4,128
14년 전 조회 2,531
14년 전 조회 953
14년 전 조회 1,264
14년 전 조회 4,084
14년 전 조회 2,404
14년 전 조회 1,554
14년 전 조회 3,932
14년 전 조회 2,597
14년 전 조회 676
14년 전 조회 2,595
14년 전 조회 723
14년 전 조회 960
14년 전 조회 1,808
14년 전 조회 1,428
14년 전 조회 1,677
14년 전 조회 1,240
14년 전 조회 2,246
14년 전 조회 911
14년 전 조회 926
14년 전 조회 751
14년 전 조회 1,560
14년 전 조회 1,181
14년 전 조회 896
14년 전 조회 5,424
14년 전 조회 2,024
14년 전 조회 1,270
14년 전 조회 756
14년 전 조회 9,553
14년 전 조회 1,681