COMING SOON 🚀

from_camel_case, to_camel_case

· 14년 전 · 1500
표기법이 달라 같은 엔티티 참조가 어려울때, 한쪽의 표기법을 변경하는 방법
자바나 자바스크립트 변수명 또는 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,201
14년 전 조회 5,281
14년 전 조회 2,170
14년 전 조회 1,948
14년 전 조회 1,433
14년 전 조회 1,676
14년 전 조회 1,467
14년 전 조회 1,363
14년 전 조회 1,437
14년 전 조회 1,426
14년 전 조회 1,406
14년 전 조회 2,243
14년 전 조회 1,575
14년 전 조회 1,432
14년 전 조회 1,370
14년 전 조회 1,432
14년 전 조회 1,760
14년 전 조회 1,675
14년 전 조회 2,280
14년 전 조회 1,866
14년 전 조회 4,327
14년 전 조회 1,549
14년 전 조회 2,133
14년 전 조회 1,852
14년 전 조회 3,588
14년 전 조회 3,213
14년 전 조회 1,382
14년 전 조회 2,420
14년 전 조회 1,409
14년 전 조회 3,201
14년 전 조회 2,770
14년 전 조회 1,340
14년 전 조회 6,478
14년 전 조회 1,734
14년 전 조회 2,265
14년 전 조회 2,044
14년 전 조회 2,028
14년 전 조회 1,974
14년 전 조회 1,983
14년 전 조회 1,811
14년 전 조회 2,154
14년 전 조회 2,537
14년 전 조회 1,564
14년 전 조회 1,975
14년 전 조회 2,963
14년 전 조회 2,820
14년 전 조회 1,817
14년 전 조회 2,264
14년 전 조회 4,762
14년 전 조회 1,501
14년 전 조회 3,473
14년 전 조회 2,233
14년 전 조회 2,700
14년 전 조회 1,902
14년 전 조회 1,660
14년 전 조회 1,670
14년 전 조회 1,790
14년 전 조회 1,867
14년 전 조회 2,770
14년 전 조회 4,006
14년 전 조회 3,084
14년 전 조회 1,802
14년 전 조회 2,379
14년 전 조회 2,637
14년 전 조회 1,434
14년 전 조회 2,699
14년 전 조회 3,914
14년 전 조회 2,572
14년 전 조회 3,524
14년 전 조회 4,802
14년 전 조회 4,878
14년 전 조회 3,282
14년 전 조회 1,714
14년 전 조회 2,022
14년 전 조회 4,829
14년 전 조회 3,145
14년 전 조회 2,297
14년 전 조회 4,688
14년 전 조회 3,335
14년 전 조회 1,430
14년 전 조회 3,341
14년 전 조회 1,462
14년 전 조회 1,711
14년 전 조회 2,577
14년 전 조회 2,186
14년 전 조회 2,441
14년 전 조회 1,970
14년 전 조회 2,991
14년 전 조회 1,656
14년 전 조회 1,668
14년 전 조회 1,489
14년 전 조회 2,309
14년 전 조회 1,908
14년 전 조회 1,632
14년 전 조회 6,182
14년 전 조회 2,770
14년 전 조회 2,017
14년 전 조회 1,532
14년 전 조회 1만
14년 전 조회 2,425