包含substr不够补零的词条

http://www.itjxue.com  2023-01-22 11:34  来源:未知  点击次数: 

数据库时间处理

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

(责任编辑:IT教学网)

更多

推荐windows vista文章