包含substr不够补零的词条
数据库时间处理
1.分钟转成不同格式的时间
数据库里有个字段 存的分钟
① 现在想显示成HH:MM格式 假设为514分钟
SELECT to_char((to_date('00:00','HH24:MI')+514/24/60),'HH24:MI') from dual
输出结果:
08:34
②如果存的是秒 同理
SELECT to_char((to_date('00:00:00','HH24:MI:SS')+514/24/60/60),'HH24:MI:SS') from dual
输出结果:
00:08:34
至于显示成其他的格式,也就不成问题了
2.时分相加
至于为什么要写这个,是因为Oracle里没有两个时间相加的处理,两个to_date相减可以,相加就出错了:
数据库里有两个字段 存的都是HH:MM格式的时间
假设一个是本月上午缺勤时间合计: 08:30(8个半小时)
另外一个是本月下午缺勤时间合计: 00:30(半小时)
现在想要总缺勤时间,显示成 HH:MM格式
做法有两种
① 正常的逻辑运算(代码或者PLSQL实现的应该比这个容易的多,仅限于SQL实现):
select LPAD((substr('08:30',1,2) + substr('00:30',1,2)+(substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2))/60),2,'0') || ':' || LPAD(mod((substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2)),60),2,'0') from dual
看起来很复杂,而实际上就是把小时相加,分钟相加,之后把分钟满60的小时进位,取余的显示:
取前两位相加得小时:(是因为不确定数据储存的格式是不是严格的HH:MM,而不能借正则分隔“:”)
(substr('08:30',1,2) + substr('00:30',1,2)
取后两位相加得分钟:
(substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2))
把分钟满60的小时进位得显示用的小时: (substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2))/60
现在小时算完了,不足两位左补零:
LPAD((substr('08:30',1,2) + substr('00:30',1,2)+(substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2))/60),2,'0')
把分钟取余得显示用的分钟:
mod((substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2)),60)
现在分钟算完了,不足两位左补零: LPAD(mod((substr('08:30',length('08:30')-1,2)+substr('00:30',length('00:30')-1,2)),60),2,'0')
最后连上“:”就变成上述的SQL,得到的时间用HH:MM显示了
输出结果:
09:00
②函数实现:
SELECT to_char(to_date('00:00','HH24:MI') +(((to_date('08:30','HH24:MI') - trunc(to_date('08:30','HH24:MI'))) *24*60 + (to_date('00:30','HH24:MI') - trunc(to_date('00:30','HH24:MI'))) *24*60)/24/60),'HH24:MI') from dual
首先把HH:MM的换成数值:
to_date('08:30','HH24:MI') - trunc(to_date('08:30','HH24:MI'))
输出结果:.354166666666666666666666666666666666666(其实是代表了一个时间,是以天为单位的)
现在*24*60 把数值换成分钟:
(to_date('08:30','HH24:MI') - trunc(to_date('08:30','HH24:MI'))) *24*60
输出结果:510
也就是把08:30 变成了510分
(to_date('00:30','HH24:MI') - trunc(to_date('00:30','HH24:MI'))) *24*60
输出结果:30(时间是.020833333333333333333333333333333333333)这两个
也就是把00:30 变成了30分
然后把两个分钟相加:
((to_date('08:30','HH24:MI') - trunc(to_date('08:30','HH24:MI'))) *24*60 + (to_date('00:30','HH24:MI') - trunc(to_date('00:30','HH24:MI'))) *24*60)
输出结果:540
剩下的就是显示处理了,和1里面的做法一致:
to_char(to_date('00:00','HH24:MI') +(((to_date('08:30','HH24:MI') - trunc(to_date('08:30','HH24:MI'))) *24*60 + (to_date('00:30','HH24:MI') - trunc(to_date('00:30','HH24:MI'))) *24*60)/24/60),'HH24:MI')
PHP数字字符串左侧补0、字符串填充和自动补齐的几种方法
一、数字补0.
如果要自动生成学号,自动生成某某编号,就像这样的形式“d0000009”、“d0000027”时,那么就会面临一个问题,怎么把左边用0补齐成这样8位数的编码呢?我想到了两种方法实现这个功能。
方法一:
先构造一个数字10000000,千万,也就是一个1,7个0,然后加上当前的编号(比如是3),那么就得到
10000003,用字符串截取
substr('10000003',1,7)后就得到0000003,最后在与“d”拼接,就得到了最终的编号d0000003。
源码如下:
复制代码
代码如下:
?php
$num
=
3;
$temp_num
=
10000000;
$new_num
=
$num
+
$temp_num;
$real_num
=
"d".substr($new_num,1,7); //即截取掉最前面的“1”
echo
$real_num;
?
方法二:
测出当前编号(比如是3)的长度strlen('3')=1,用要生成编号的总长度减去当前编号长度,得到需要填充0的个数,然后再用for循环填充0即可。
源码如下:
复制代码
代码如下:
?php
$num
=
3;
$bit
=
7;//产生7位数的数字编号
$num_len
=
strlen($num);
$zero
=
'';
for($i=$num_len;
$i$bit;
$i++){
$zero
.=
"0";
}
$real_num
=
"d".$zero.$num;
echo
$real_num;
?
方法三:另外几种方法
复制代码
代码如下:
?php
$sourceNumber
=
"1";
$newNumber
=
substr(strval($sourceNumber+1000),1,3);
echo
"$newNumber";
?
/*这个时候就会出现:001
如果要增加位数的话可以将1000加大,然后把3也加大。
举例:如果我要补上
"4个0"
第03行
就要变成这样。*/
复制代码
代码如下:
?php
$newNumber
=
substr(strval($sourceNumber+100000),1,5);
?
/*其实就是总共要显示几位数字,就把$sourceNumber+1后面补上多少个0,最后一个数字就直接改成显示几位数字。*/
复制代码
代码如下:
/*string
str_pad
(
string
$input,
int
$pad_length
[,
string
$pad_string
[,
int
$pad_type]]
)*/
?php
$input
=
"Alien";
echo
str_pad($input,
10);
//
produces
"Alien
"
echo
str_pad($input,
10,
"-=",
STR_PAD_LEFT);
//
produces
"-=-=-Alien"
echo
str_pad($input,
10,
"_",
STR_PAD_BOTH);
//
produces
"__Alien___"
echo
str_pad($input,
6
,
"___");
//
produces
"Alien_"
?
/*补齐字符串的长度.以pad_string
补.默认补在右边,如果STR_PAD_LEFT就补到左边,STR_PAD_BOTH两边一起补。下次用str_pad,毕竟是内置的,肯定比自定义的快。*/
复制代码
代码如下:
/*
你上面的方法我觉得不怎么好,介绍一下我写的一个方法。方法函数如下,这样当你要的结果001的话,方法:dispRepair('1',3,'0')
功能:补位函数
str:原字符串
type:类型,0为后补,1为前补
len:新字符串长度
msg:填补字符
*/
function
dispRepair($str,$len,$msg,$type='1')
{
$length
=
$len
-
strlen($str);
if($length1)return
$str;
if
($type
==
1)
{
$str
=
str_repeat($msg,$length).$str;
}
else
{
$str
.=
str_repeat($msg,$length);
}
return
$str;
}
二、字符串填充、自动补齐、自动补全
遇到要输出一定长度字符串的时候,可以使用一下两种方法进行PHP字符串自动填充、自动补全
。
方法一:
复制代码
代码如下:$newStr=
sprintf('%05s',
$str);
sprintf()的功能非常灵活,上面的格式字符串中,“%05s
”表示输出成长度为5的字符串,如果长度不足,左边以零补全;如果写成
“%5s
”,则默认以空格补全;如果希望使用其它字符补全,则要在该字符前加上单引号,即形如“%'#5s
”的表示以井号补全;最后,如果希望补全发生在
字符串右边,则在百分号后加上减号,“%-05s
”。
方法二:
[code]$cd_no
=
str_pad(++$next_cd_no,8,'#',STR_PAD_LEFT);
str_pad(string,length,pad_string,pad_type):具体用法查看手册。
string
必需。规定要填充的字符串。
length
必需。规定新字符串的长度。如果该值小于原始字符串的长度,则不进行任何操作。
pad_string
可选。规定供填充使用的字符串。默认是空白。
pad_type
可选。规定填充字符串的那边。
这两种方法很方便的实现了PHP字符串的自动补全功能。
求个正则表达式,怎样在左边补0
my $a="0x64"; hex字符串
$a=substr($a,2,$]); 去掉0x
我想保持整个十六进制字符串的宽度为8个字节 即0000000000000000
想join 16-length($a) 个0到左边 这个正则表达式怎么写呢
join(/0{16-length($_)}/,$a)
小弟刚学正则 还不太明白 希望大侠帮忙改改
javascript 中始终效果不够10位补一个0的效果怎么实现
下面是我写的一个方法,?应该可以满足你的要求
/**
?*?@param?num:?需要固定位数的数字或字符串;
?*?@param?totalBit:?保证返回字符串的长度,?默认为10;
?*?@param?isFront:?当num位数不足时,?新填充的字符串是否位于num前面,?默认为true;
?*?@param?fixedChar:?当num位数不足时,?重复填充此字符,?默认为'0';
?*?@param?alwaysCut:?是否始终保证返回值长度为totalBit,?此值为true时,?如果给定num的长东超过参数中totalBit的大小时,?也会截取totalBit长度的字符串,?默认为false
?*?**/
function?toFixedBit(num,?totalBit,?isFront,?fixedChar,?alwaysCut)?{
????if?(totalBit?===?void?0)?{?totalBit?=?10;?}
????if?(isFront?===?void?0)?{?isFront?=?true;?}
????if?(fixedChar?===?void?0)?{?fixedChar?=?"0";?}
????if?(alwaysCut?===?void?0)?{?alwaysCut?=?false;?}
????var?nn?=?num.toString();
????if?(!alwaysCut??nn.length?=?totalBit)?{
????????return?nn;
????}
????var?rtn?=?"";
????for?(var?i?=?0;?i??totalBit;?i++)?{
????????rtn?+=?fixedChar;
????}
????if?(isFront)?{
????????rtn?+=?nn;
????????rtn?=?rtn.substr(rtn.length?-?totalBit);
????}
????else?{
????????rtn?=?nn?+?rtn;
????????rtn?=?rtn.substr(0,?totalBit);
????}
????return?rtn;
}
使用方法
console.log(toFixedBit(100));?//输出:?0000000100
console.log(toFixedBit(100,?10,?false));//输出:?1000000000
console.log(toFixedBit(100,?10,?true,?"$",?false));//输出:?$$$$$$$100
console.log(toFixedBit("aasadfsa4512122",?10,?true,?"$",?true));//输出:?fsa4512122
console.log(toFixedBit("aasadfsa4512122",?10,?false,?"$",?true));//输出:?aasadfsa45
console.log(toFixedBit("aasadfsa4512122",?10,?false,?"$",?false));//输出:?aasadfsa4512122