DEVELOPERS BLOGデベロッパーズブログ

  1. HOME > 
  2. 加藤 正人のデベロッパーズブログ > 
  3. CakePHP の小ネタ

加藤 正人のデベロッパーズブログ

加藤 正人

氏名
加藤 正人
役職
多分SE
血液型
秘密
出没
美味しいもののあるところ
特色
タヒチ大好き。ちょいメタボ。

PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)

2013/05/25

PhpSpreadsheet でExcel ファイルを読み込む (CakePHP3)

 

仕事でよく金額表示をすることがあるので、整数⇒日本式位取り数の変換をするヘルパーを作ってみた。

<?php
App::uses('AppHelper', 'View/Helper');

// 数値を取り扱うヘルパー
class NumberConverterHelper extends AppHelper
{
	// 整数 ⇒ 命数法による位取り数値
	//
	// japaneseNumeral(15000) ⇒ '1万5000'
	// japaneseNumeral(10000, '万') ⇒ '1億'
	// japaneseNumeral(15000, '万') ⇒ '1億5000万'
	// japaneseNumeral(15000, '億') ⇒ '1兆5000億
	//
	// パラメータ:
	//		$num: 位取り対象となる数値
	//		$base: 位取りの最小単位 (万、億、兆など)
	//		$skipZero: TRUE の場合、各位の値が0の時にその位を表示しない。既定値は TRUE。
	public function japaneseNumeral($num=NULL, $base=NULL, $skipZero=TRUE)
	{
		// 位取りは「塵劫記」による。 http://ja.wikipedia.org/wiki/命数法
		if ( is_null($num) || !preg_match('/^[0-9]+$/', ($num=(string)$num)) )
		{
			// 入力値が正しくない ⇒ NULL を返す
			return NULL;
		}
		if ( ($supless=strlen($num) % 4) > 0 )
		{
			$num = substr("0000", $supless) . $num;	// 4桁区切りにできるよう先頭に '0' を補う
		}
		$numbers = array_reverse(explode(',', rtrim(chunk_split($num, 4, ','), ',')));

		$placeNames = array(NULL, '万', '億', '兆', '京', '垓', '秄', '穣', '溝', '澗', '正', '載', '極', '恒河沙', '阿僧祇', '那由他', '不可思議', '無量大数');
		$start = array_search($base, $placeNames);
		$ret = NULL;
		for ($i=0, $j=$start; $i<count($numbers); $i++, $j++)
		{
			if ( ($n=intval($numbers[$i],10)) == 0 && $skipZero )
			{
				$ret[] = '';
			}
			else
			{
				$ret[] = ((string)$n) . $placeNames[$j];
			}
		}
		return implode('', array_reverse($ret));
	}
}
?>

これをヘルパーとして登録しビュー内で $this->NumberConverter->japaneseNumeral(...) のようにすることで整数値を日本式位取りの数値表記に変換することができる。

ただコードとしてはあまり効率の良いコードではないのでもう少し高速化を考えてみたいかも。

関連タグ: CakePHP2 

関連エントリー