from_camel_case, to_camel_case

· 14년 전 · 757
표기법이 달라 같은 엔티티 참조가 어려울때, 한쪽의 표기법을 변경하는 방법
자바나 자바스크립트 변수명 또는 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,485
14년 전 조회 4,567
14년 전 조회 1,453
14년 전 조회 1,218
14년 전 조회 717
14년 전 조회 957
14년 전 조회 761
14년 전 조회 651
14년 전 조회 723
14년 전 조회 712
14년 전 조회 663
14년 전 조회 1,539
14년 전 조회 840
14년 전 조회 715
14년 전 조회 663
14년 전 조회 735
14년 전 조회 1,025
14년 전 조회 925
14년 전 조회 1,514
14년 전 조회 1,137
14년 전 조회 3,599
14년 전 조회 822
14년 전 조회 1,373
14년 전 조회 1,119
14년 전 조회 2,847
14년 전 조회 2,458
14년 전 조회 663
14년 전 조회 1,701
14년 전 조회 681
14년 전 조회 2,464
14년 전 조회 2,017
14년 전 조회 635
14년 전 조회 5,720
14년 전 조회 980
14년 전 조회 1,496
14년 전 조회 1,314
14년 전 조회 1,340
14년 전 조회 1,230
14년 전 조회 1,232
14년 전 조회 1,049
14년 전 조회 1,413
14년 전 조회 1,806
14년 전 조회 824
14년 전 조회 1,203
14년 전 조회 2,233
14년 전 조회 2,082
14년 전 조회 1,053
14년 전 조회 1,530
14년 전 조회 4,032
14년 전 조회 758
14년 전 조회 2,738
14년 전 조회 1,505
14년 전 조회 1,967
14년 전 조회 1,167
14년 전 조회 934
14년 전 조회 951
14년 전 조회 1,086
14년 전 조회 1,168
14년 전 조회 2,048
14년 전 조회 3,293
14년 전 조회 2,332
14년 전 조회 1,055
14년 전 조회 1,653
14년 전 조회 1,914
14년 전 조회 702
14년 전 조회 1,943
14년 전 조회 3,173
14년 전 조회 1,857
14년 전 조회 2,787
14년 전 조회 4,103
14년 전 조회 4,144
14년 전 조회 2,546
14년 전 조회 968
14년 전 조회 1,275
14년 전 조회 4,101
14년 전 조회 2,421
14년 전 조회 1,566
14년 전 조회 3,951
14년 전 조회 2,610
14년 전 조회 695
14년 전 조회 2,609
14년 전 조회 741
14년 전 조회 969
14년 전 조회 1,819
14년 전 조회 1,439
14년 전 조회 1,687
14년 전 조회 1,254
14년 전 조회 2,265
14년 전 조회 931
14년 전 조회 937
14년 전 조회 767
14년 전 조회 1,570
14년 전 조회 1,193
14년 전 조회 906
14년 전 조회 5,439
14년 전 조회 2,048
14년 전 조회 1,281
14년 전 조회 773
14년 전 조회 9,573
14년 전 조회 1,689