Erjing’s Blog

September 25, 2008

奶牛产奶需要受孕吗?公奶牛产奶吗?奶牛是不是可以永久性产奶?N个问题俺总算搞清楚了。

Filed under: I love life — Tags: — erjing @ 10:25 am

无标题文档我想是个人基本都会喝过牛奶,大家没见过奶牛,也看过奶牛的照片吧,很多人一定以为奶牛是一个专用的品种,应该是通过某种基因改良,生下来几天就长大,长大了就能产奶了….其实….

昨天和朋友聊奶牛,今天特地去CCTV上查询了一下,开始回放:

问您个事啊,奶牛有公的吗?要是有的话,它产不产奶呢?奶牛是从什么时候开始产奶的呢?是不是一生下来就有奶呢?这些问题听起来简单吧,可有如此疑问的人还真不在少数。


应该没公的吧公奶牛不会有!

我觉得不会有

有! 应该有吧

您看看,问题虽然很简单,可是回答的人都似事而非的!看来真正了解奶牛的人并不多呀,既然如此,咱们就到奶牛场看看去。

这里是北京市通州区的一家养牛场,关于奶牛的问题,咱们先到这儿找找答案。这么多的奶牛里,公奶牛肯定也有吧,要不然怎么下小牛犊呀!

这个圈里养的全是1岁多的公奶牛,与它们同龄的母奶牛都能清楚地看到乳房了,而公奶牛不论是站着、还是卧着,都看不到乳房,所以这公奶牛肯定是产不了奶的。既然它产不了奶,为什么还叫奶牛呢?

北京市奶牛中心三元绿荷第一牧场高级畜牧师李俊鹏 通俗地讲 奶牛之所以叫奶牛 是因为第一具备产奶能力 它能产奶 第二它产奶量高 像黄牛 役用牛它不叫奶牛 是因为它虽然具备产奶能力 但它产奶量太低了

奶牛作为一个品种,是相对于肉牛和役用牛来说的。奶牛产奶多,那一头奶牛一天能产多少奶呢?

一天起码能产五升吧 我估计四 五升

几升吧

奶牛一天才产几升的奶!这恐怕也太少了吧!那它一天到底能产多少奶、这些奶又是怎么挤出来的呢?咱们到挤奶的地方瞧瞧去!

过去挤牛奶,都是用手工,又费时又费力,现在都改用机器挤奶了。这蓝盖的小盒子就是吸奶泵,吸奶管一旦对准了乳头,奶就 被吸到泵里,顺着管道汇集到一 起。奶越吸越少,泵的动力也越来越小,奶的流量跟不上趟时,泵就不再使劲,吸奶管自动脱落。这个仪表盘上的数字就是奶牛的产量,这头奶牛一次产了18.8 公斤的奶。如果咱们每天喝一斤奶的话,这一头奶牛一次产的奶就够咱喝上1个多月了!

奶牛一天要挤三次奶,早上、中午、晚上各一次。高产奶牛一天能产奶30多公斤,一年能产奶9000多公斤,9000多公斤是个什么概念呢?

北京市三元奶牛养殖中心 宣传部部长 张九迎:这是咱们载重量9吨的奶车 咱们一头奶牛一年的产奶量能装满这一罐奶车

记者出场:没想到吧,一头奶牛一年能有这么大的产奶量,对养牛的朋友来说,产奶多就意味着什么?钱多,所以真得把这些奶牛给伺候好喽。不过话说回来,这奶牛可不是一生下来就会产奶,那它长到多大、得具备什么条件才能产奶呢?

我觉得它应该长着长着就产奶了 不是生小牛才有奶的 否则那得生多少小牛啊

一般就是比较好的奶牛要到四五年才行 要是能产奶的话 应该是再小一点也行

大部分的人都认为,奶牛之所以叫奶牛,是因为它天生就会产奶。所以,小牛长到一定的程度,自然就能产奶了,事实果真如此吗?

这是一头刚出生的小奶牛,像其他的小奶牛一样,它也要在这里生活上两个多月,这里就是小奶牛们的保育院!小家伙们的一日三餐,都由专业的保育院阿姨来照顾。现在是上午的9点多种,阿姨来送早点了!这位沾了离路边近的光,先吃上了!

没出满月的小奶牛乳房都没有发育,就连乳头也要把拉开毛才能看清楚。这个时候的小奶牛别说产奶了,它还要靠吃妈妈的奶才能生活呢。

两个月的保育院幸福时光很快就过去了,小奶牛们已经断了奶,家也搬到了这个大院子里,过起了自己找饭吃的集体生活。

北京三元奶牛养殖中心第一牧场 高级畜牧师 李俊鹏:按它们的年龄算的话 应该相当于小孩的幼儿园 要说幼儿园的话也就是大班 它们现在能产奶了吗 现在还产不了奶

刚刚学会生活自理的小奶牛们,对什么都感兴趣,它们一天到晚东游西逛,时不时地露出个乳房的小轮廓!

奶牛长到一岁了,已经出落成一个标致的奶牛小姐了!不光毛色亮丽,举止也优雅端庄了些,尤其是它的乳房已经发育完全了,这时候的小牛是不是就可以产奶了呢?

北京三元奶牛养殖中心第一牧场 级畜牧师 李俊鹏:这个阶段的牛相当于人的哪个年龄段 十四五岁 相当于人的青春期 也不会产奶

看来,小牛得等到长大成年后才能产奶了,那么小奶牛长到多大才算成年了呢?

北 京三元奶牛养殖中心第一牧场高级畜牧师 李俊鹏:成年的标准应该是分娩以后 开始泌乳 按现在这个月龄来说 它达到了性成熟 具备了繁殖生育的能力 但是它还没有达到体成熟 体成熟有两个非常重要的指标 一个是体重 应该达到380公斤左右 体高的话应该达到127厘米左右 只有达到这两个标准 才能够配种

原来,奶牛也并不是天生就会产奶,而是要等到分娩生子后才可以。这个大院居住的都是已经怀上了小牛的准妈妈们。瞧瞧,它们是一个比一个懒,一个比一个爱嚼果,它们还要过多长时间才产小牛呢?

北京三元奶牛养殖中心第一牧场高级畜牧师 李俊鹏:一般奶牛的怀孕期是280天 那么简单地推算预产期的方法是减3加6 也就说配种月份减3 配种日期加6 就可以推算出一头奶牛的分娩日期

咱打个比方说,如果有一头奶牛是在2006年的6月25日配种成功的话,套用推算公式:6月减3为3月,25日加6为31日,那么那头奶牛的分娩日期应该是在2007年3月31日左右。

有倒是牛尾巴打死个苍蝇:赶巧了,听说今天也有奶牛分娩了,那它是不是已经有奶了呢?咱赶紧瞧瞧去!

北京三元奶牛养殖中心第一牧场 畜牧师 武生志 可以产奶了 因为它刚刚生完小牛 它吊着的那个是什么 那是它的胎盘 也称脱衣 胎衣大体在产完牛犊后的8-12个小时就可以排除

看,奶牛的乳头上已经有乳汁流出了,这是它的初乳!(二斤注:这就是所谓的牛初乳啦!

奶牛从当上妈妈的第一天起,就开始产奶了。这生育子女就如同是打开了它的产奶伐门。这伐门一旦打开了,奶牛一生是不是就一直可以产奶了呢?

北京三元奶牛养殖中心第一牧场畜牧师 武生志 不可能 因为随着它泌乳时间的生长 它的产奶量在逐渐地减少 这样需要奶牛继续怀孕继续产犊 进入到下一胎次的产奶

奶牛的妊娠期是280天, 生下牛犊后产奶305天,那么大体上来说奶牛是不是一年怀小牛,一年产奶呢?事实上可不是这么回事。奶牛的幸福时光只有两年多,从它产下头胎小牛后的第 60天就要接受人工受精,它是边产奶边孕育小牛,直到预产期前的两个月,才可以断奶休息。而两个月后第二胎小牛落地,它就又进入到下一个产奶、怀孕循环。

记者出场:您看,这当奶牛可真是不容易的,要想多产奶,就得不断地重复怀孕、生产的过程,多辛苦啊。知道了这些,咱们是不是也得多讲究点动物福利,好好对待它们呢?

二斤总结性发言:这才清楚了,原来即便是奶牛,也需要首先受孕的,产下第一胎才会产奶,这就是牛初乳。按照奶牛的品种不一样,每天产奶的量和次数都不一样。为了保证奶牛产奶,奶牛一年基本上没有几天休息的,同时要保证在一个很高的受孕率环境下。

不同的奶牛受孕率不一样,比如奶牛奶水牛的受孕率就不一样,为了提高受孕率,人们想了很多办法,通常是人工加自动(就是公牛去干该干的事情)。提高受孕率也是奶牛产奶的重要保证。受孕的间隔,如何受孕,要根据不同的品种以及品种的实际情况来决定了。

奶牛产下的小牛怎么办?其实小牛喝不了那么多牛奶的,一般来说奶牛带三个月,就隔离开育青了。至于小牛的前途…当下一代奶牛..当下一代公牛…还是下一代餐桌美食…管不了那么多….

特别提示,新疆部分奶牛品种已经有了一天44公斤产量的记录,但是早上就能产奶22公斤。具体奶的质量不清楚,比如蛋白质含量,脂肪含量…各种维生素含量…

今天学习新知识了。

Filed under: I love life — erjing @ 3:19 am

今天去guqi和羊蹄子的咖啡屋转了一圈,看到了guqi的作品。

让俺张了不少见识。看来摄影还是要多学习,多和高手学习,多观摩高手的作品才行。

September 18, 2008

正则表达式。

Filed under: linux, linux script, 计算机与 Internet — erjing @ 10:39 pm
中国电话号码验证 
匹配形式如:0511-4405222或者021-878888822或者 021-44055520-555 或者 (0511)44052222
正则表达式 “((d{3,4})|d{3,4}-)?d{7,8}(-d{3})*”

中国邮政编码验证
匹配形式如:215421
正则表达式 “d{6}”

电子邮件验证
匹配形式如:justali@justdn.com
正则表达式 “w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*”

身份证验证
匹配形式如:15位或者18位身份证
正则表达式 “d{18}|d{15}”

常用数字验证
正则表达式
“d{n}” n为规定长度
“d{n,m}” n到m的长度范围

非法字符验证
匹配非法字符如:< > & / ‘ |
正则表达式 [^<>&/|’\]+

日期验证
匹配形式如:20030718,030718
范围:1900–2099
正则表达式((((19){1}|(20){1})d{2})|d{2})[01]{1}d{1}[0-3]{1}d{1}
正则表达式是一个好东西,但是一般情况下,我们需要验证的内容少之又少。下面是常用的17种正则表达式:

“^\d+$”  //非负整数(正整数 + 0)

“^[0-9]*[1-9][0-9]*$”  //正整数

“^((-\d+)|(0+))$”  //非正整数(负整数 + 0)

“^-[0-9]*[1-9][0-9]*$”  //负整数

“^-?\d+$”    //整数

“^\d+(\.\d+)?$”  //非负浮点数(正浮点数 + 0)

“^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$”  //正浮点数

“^((-\d+(\.\d+)?)|(0+(\.0+)?))$”  //非正浮点数(负浮点数 + 0)

“^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$”  //负浮点数

“^(-?\d+)(\.\d+)?$”  //浮点数

“^[A-Za-z]+$”  //由26个英文字母组成的字符串

“^[A-Z]+$”  //由26个英文字母的大写组成的字符串

“^[a-z]+$”  //由26个英文字母的小写组成的字符串

“^[A-Za-z0-9]+$”  //由数字和26个英文字母组成的字符串

“^\w+$”  //由数字、26个英文字母或者下划线组成的字符串

“^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$”    //email地址

“^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$”  //url

[code]电子邮件 : @”^\w+((-\w+)|(\.\w+))*\@\w+((\.|-)\w+)*\.\w+$”
HTTP URL : @”^http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?”;
邮编 : @”\d{6}”
身份证 : @”\d{18}|\d{15}”
整数 : @”^\d{1,}$”
数值 : @”^-?(0|\d+)(\.\d+)?$”
日期 : @”^(?:(?:(?:(?:1[6-9]|[2-9]\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00)))(\/|-|\.)(?:0?2\1(?:29))$)|(?:(?:1[6-9]|[2-9]\d)?\d{2})(\/|-|\.)(?:(?:(?:0?[13578]|1[02])\2(?:31))|(?:(?:0?[1,3-9]|1[0-2])\2(29|30))|(?:(?:0?[1-9])|(?:1[0-2]))\2(?:0?[1-9]|1\d|2[0-8]))$”
合法的用户名(以字母开头,长度不小于4) : @”(([a-zA-Z]){1})+(\w{3,29})”[/code]
[code]常用正则表达式语法例句
这里有一些可能会遇到的正则表达式示例:

/^\[ \t]*$/ “^\[ \t]*$” 匹配一个空白行。

/\d{2}-\d{5}/ “\d{2}-\d{5}” 验证一个ID号码是否由一个2位字,一
个连字符以及一个5位数字组成。

/<(.*)>.*<\/\1>/ “<(.*)>.*<\/\1>” 匹配一个 HTML 标记。

下表是元字符及其在正则表达式上下文中的行为的一个完整列表:

字符 描述

\ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个 后
向引用、或一个八进制转义符。例如,’n’ 匹配字符 “n”。’\n’
匹配一个换行符。序列 ‘\\’ 匹配 “\” 而 “\(” 则匹配 “(”。

^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的
Multiline 属性,^ 也匹配 ‘\n’ 或 ‘\r’ 之后的位置。

$ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的
Multiline 属性,$ 也匹配 ‘\n’ 或 ‘\r’ 之前的位置。

* 匹配前面的子表达式零次或多次。例如,zo* 能匹配 “z” 以及
“zoo”。 * 等价于{0,}。

+ 匹配前面的子表达式一次或多次。例如,’zo+’ 能匹配 “zo” 以
及 “zoo”,但不能匹配 “z”。+ 等价于 {1,}。

? 匹配前面的子表达式零次或一次。例如,”do(es)?” 可以匹配
“do” 或 “does” 中的”do” 。? 等价于 {0,1}。

{n} n 是一个非负整数。匹配确定的 n 次。例如,’o{2}’ 不能匹配
“Bob” 中的 ‘o’,但是能匹配 “food” 中的两个 o。

{n,} n 是一个非负整数。至少匹配n 次。例如,’o{2,}’ 不能匹配
“Bob” 中的 ‘o’,但能匹配 “foooood” 中的所有 o。’o{1,}’
等价于 ‘o+’。’o{0,}’ 则等价于 ‘o*’。

{n,m} m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹
配 m 次。刘, “o{1,3}” 将匹配 “fooooood” 中的前三个o。
‘o{0,1}’等价于’o?’。请注意在逗号和两个数之间不能有空格

? 当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,},
{n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的
匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜
索的字符串。例如,对于字符串 “oooo”,’o+?’ 将匹配单个
“o”,而 ‘o+’ 将匹配所有 ‘o’。

. 匹配除 “\n” 之外的任何单个字符。要匹配包括 ‘\n’ 在内的任
何字符,请使用象 ‘[.\n]’ 的模式。

(pattern) 匹配pattern 并获取这一匹配。所获取的匹配可以从产生的
Matches 集合得到,在VBScript 中使用 SubMatches 集合,在
Visual Basic Scripting Edition 中则使用 $0…$9 属性。要
匹配圆括号字符,请使用 ‘\(’ 或 ‘\)’。

(?:pattern) 匹配 pattern 但不获取匹配结果,也就是说这是一个非获取匹
配,不进行存储供以后使用。这在使用 “或” 字符 (|) 来组合
一个模式的各个部分是很有用。例如, ‘industr(?:y|ies) 就
是一个比 ‘industry|industries’ 更简略的表达式。

(?=pattern) 正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符
串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后
使用。例如,’Windows (?=95|98|NT|2000)’ 能匹配”Windows
2000″中的”Windows”,但不能匹配”Windows3 .1″中”Windows”。
预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹
配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之
后开始。

(?!pattern) 负向预查,在任何不匹配Negative lookahead matches the
search string at any point where a string not matching
pattern 的字符串开始处匹配查找字符串。这是一个非获取匹
配,也就是说,该匹配不需要获取供以后使用。例如’Windows
(?!95|98|NT|2000)’ 能匹配 “Windows 3.1″ 中的 “Windows”,
但不能匹配 “Windows 2000″ 中的 “Windows”。预查不消耗字
符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开
始下一次匹配的搜索,而不是从包含预查的字符之后开始

x|y 匹配 x 或 y。例如,’z|food’ 能匹配 “z” 或 “food”。’(z|f)
ood’ 则匹配 “zood” 或 “food”。

[xyz] 字符集合。匹配所包含的任意一个字符。例如, ‘[abc]’ 可以
匹配 “plain” 中的 ‘a’。

[^xyz] 负值字符集合。匹配未包含的任意字符。例如, ‘[^abc]’ 可以
匹配 “plain” 中的’p'。

[a-z] 字符范围。匹配指定范围内的任意字符。例如,’[a-z]’ 可以匹
配 ‘a’ 到 ‘z’ 范围内的任意小写字母字符。

[^a-z] 负值字符范围。匹配任何不在指定范围内的任意字符。例如,
‘[^a-z]’ 可以匹配任何不在 ‘a’ 到 ‘z’ 范围内的任意字符。

\b 匹配一个单词边界,也就是指单词和空格间的位置。例如,
‘er\b’ 可以匹配”never” 中的 ‘er’,但不能匹配 “verb” 中
的 ‘er’。

\B 匹配非单词边界。’er\B’ 能匹配 “verb” 中的 ‘er’,但不能匹
配 “never” 中的 ‘er’。

\cx 匹配由x指明的控制字符。例如, \cM 匹配一个 Control-M 或
回车符。 x 的值必须为 A-Z 或 a-z 之一。否则,将 c 视为一
个原义的 ‘c’ 字符。

\d 匹配一个数字字符。等价于 [0-9]。

\D 匹配一个非数字字符。等价于 [^0-9]。

\f 匹配一个换页符。等价于 \x0c 和 \cL。

\n 匹配一个换行符。等价于 \x0a 和 \cJ。

\r 匹配一个回车符。等价于 \x0d 和 \cM。

\s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于
[ \f\n\r\t\v]。

\S 匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。

\t 匹配一个制表符。等价于 \x09 和 \cI。

\v 匹配一个垂直制表符。等价于 \x0b 和 \cK。

\w 匹配包括下划线的任何单词字符。等价于’[A-Za-z0-9_]’。

\W 匹配任何非单词字符。等价于 ‘[^A-Za-z0-9_]’。

\xn 匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确
定的两个数字长。例如, ‘\x41′ 匹配 “A”。’\x041′ 则等价
于 ‘\x04′ & “1″。正则表达式中可以使用 ASCII 编码。.

\num 匹配 num,其中num是一个正整数。对所获取的匹配的引用。
例如,’(.)\1′ 匹配两个连续的相同字符。

\n 标识一个八进制转义值或一个后向引用。如果 \n 之前至少 n
个获取的子表达式,则 n 为后向引用。否则,如果 n 为八进制
数字 (0-7),则 n 为一个八进制转义值。

\nm 标识一个八进制转义值或一个后向引用。如果 \nm 之前至少有
is preceded by at least nm 个获取得子表达式,则 nm 为后
向引用。如果 \nm 之前至少有 n 个获取,则 n 为一个后跟文
字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为
八进制数字 (0-7),则 \nm 将匹配八进制转义值 nm。

\nml 如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-
7),则匹配八进制转义值 nml。

\un 匹配 n,其中 n 是一个用四个十六进制数字表示的Unicode字
符。例如, \u00A9 匹配版权符号 (?)。 [/code]
常用正则表达式
——————————————————————————–

匹配html的嵌入代码 [code]<[^>]*>[/code]

匹配[….]的嵌入码[code] \[[^]]\{1,\}\][/code]

删除仅由空字符组成的行
[code]sed ‘/^[[:space:]]*$/d’ filename[/code]

匹配html标签
[code]/\(<[^>]*>\)/[/code]例如:从html文件中剔除html标签
[code]sed ’s/\(<[^>]*>\)//g;/^[[:space:]]*$/d’ file.html[/code]

例如:要从下列代码中去除”[]”及其中包括的代码
[code]一. 替换
sed ’s/\[[^]]\{1,\}\]//g’ filename[/code]

匹配日期:
[code]Month, Day, Year [A-Z][a-z]\{3,9\}, [0-9]\{1,2\}, [0-9]\{4\}
2003-01-28 或 2003.10.18 或 2003/10/10 或 2003 10 10
\([0-9]\{4\}[ /-.][0-2][0-9][ /-.][0-3][0-9]\)[/code]
匹配IP地址
[code]\([0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\)
\(\([0-9]\{1,3\}\.\)\{3\}[0-9]\{1,3\}\)[/code]

匹配数字串
[code][-+]*[0-9]\{1,\} 整数
[-+]*[0-9]\{1,\}\.[0-9]\{1,\} 浮点数[/code]

从字串中解析出两个子串(前2各字符和后9个字符)
[code]echo “WeLoveChinaUnix”|sed -e ‘H;s/\(..\).*/\1/;x;s/.*\(.\{9\}\)$/\1/;x;G;s/\n/ /’
We ChinaUnix [/code]

分解日期串
[code]echo 20030922|sed ’s/\(….\)\(..\)\(..\)/\1 \2 \3/’|read year month day
echo $year $month $day [/code]

文件内容倒序输出
[code]sed ‘1!G;h;$!d’ oldfile >newfile[/code]

[code]匹配中文字符的正则表达式:
[\u4e00-\u9fa5]

匹配双字节字符(包括汉字在内):
[^\x00-\xff]

匹配空行的正则表达式:
\n[\s| ]*\r

匹配HTML标记的正则表达式:
/<(.*)>.*<\/\1>|<(.*) \/>/

匹配首尾空格的正则表达式:
(^\s*)|(\s*$)

URL:
http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?

Email:
\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

中华人民共和国电话号码
(\(\d{3}\)|\d{3}-)?\d{8}

中华人民共和国邮编
\d{6}

门丁注册的id格式:2-12位,数字、字符、下划线(0-9,a-z,A-Z,_)
^[0-9a-zA-Z]+(\w){1,11}[/code]

蓝吧甜 宝宝:主人,陪我去森林里玩好不好?
你和宝宝在森林里找了个好东西给你~~管理员作的特别科研卡!
卡片说明:获得社区特别科研基金100个金币。
卡片效果:得到100金币。
你高兴我也高兴!

点击在新窗口中浏览原图 CTRL+鼠标滚轮放大或缩小

[code]匹配中文字符的正则表达式: [\u4e00-\u9fa5]

匹配双字节字符(包括汉字在内):[^\x00-\xff]

匹配空行的正则表达式:\n[\s| ]*\r

匹配HTML标记的正则表达式:/<(.*)>.*<\/\1>|<(.*) \/>/

匹配首尾空格的正则表达式:(^\s*)|(\s*$)(像vbscript那样的trim函数)

匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

匹配网址URL的正则表达式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
—————————————————————————
以下是例子:

利用正则表达式限制网页表单里的文本框输入内容:

用正则表达式限制只能输入中文:onkeyup=”value=value.replace(/[^\u4E00-\u9FA5]/g,”)” onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^\u4E00-\u9FA5]/g,”))”

1.用正则表达式限制只能输入全角字符: onkeyup=”value=value.replace(/[^\uFF00-\uFFFF]/g,”)” onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^\uFF00-\uFFFF]/g,”))”

2.用正则表达式限制只能输入数字:onkeyup=”value=value.replace(/[^\d]/g,”) “onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^\d]/g,”))”

3.用正则表达式限制只能输入数字和英文:onkeyup=”value=value.replace(/[\W]/g,”) “onbeforepaste=”clipboardData.setData(’text’,clipboardData.getData(’text’).replace(/[^\d]/g,”))”

4.计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)

String.prototype.len=function(){return this.replace([^\x00-\xff]/g,”aa”).length;}

5.javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:

String.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, “”);
}

利用正则表达式分解和转换IP地址:

6.下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:

function IP2V(ip)
{
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正则表达式
if(re.test(ip))
{
return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
}
else
{
throw new Error(”不是一个正确的IP地址!”)
}
}

不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:

var ip=”10.100.20.168″
ip=ip.split(”.”)
alert(”IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))[/code]

September 5, 2008

新疆无花果,自己栽培的猴头菇以及…廖师傅的鸡爪子.

Filed under: I love life, 新疆行 — Tags: , , — erjing @ 9:15 pm

DSC_2596.jpg
DSC_2595.jpg

新疆的无花果是扁的,不是大家通常见得那种无花果干一样圆的。楼下饭馆前拍滴,每次路过的都是俺都有抢了就跑的冲动….
DSC_2677.jpg

DSC_2679.jpg

年初栽培的猴头菇,最近天气热,总算发出来了。
DSC_2690.jpg

廖师傅的鸡爪子…美味啊。今天去红旗路顺便卖了点回来过瘾。

September 1, 2008

关于网线568A和568B。

Filed under: 计算机与 Internet — Tags: , , , — erjing @ 8:12 pm

转贴,不知道原文出处。

—- 转贴开 始  ——————————————————————————————————————————————-
关于网络设备的定义和设备间连接方式一般规律:
第一,你需要了解两类设备:DTE类设备和DCE类设备。
DTE 类设备:PC、路由器、交换机uplink口、HUB级联口
DCE 类设备:交换机普通口、HUB普通口
同类设备间相连使用交叉线方式;异类设备间相连使用直通线方式。
说明:
DTE(Data TerminalEquipment)是数据终端设备,也就是具有一定的数据处理能力以及发送和接收数据能力的设备。大家知道,大多数的数字数据处理设备 的数据传输能力是很有限的。直接将相隔很远的两个数据处理设备连接起来,是不能进行通信的。必须在数据处理设备和传输线路之间,加上一个中间设备。这个中 间设备就是数据电路端设备DCE(Data Circuit-terminatingEquipment)。DCE的作用就是在DTE和传输线路之间提供信号变换和编码的功能,并且负责建立、保持和 释放数据链路的连接。DTE可以是一台计算机或一个终端,也可以是各种的I/O设备。典型的DCE则是一个与模拟电话线路相连接的调制解调器。DCE虽然 处于通信环境内,但它和DTE均属于用户设施。用户环境只包括DTE。
例如:
PC PC 交叉线
PC HUB 直通线
HUB普通口 HUB普通口 交叉线
HUB普通口 HUB级联口 直通线
PC 路由器 交叉线
路由器 路由器 交叉线
PC 交换机 直通线
路由器 交换机 直通线
交换机普通口 交换机uplink口 直通线
交换机普通口 交换机普通口 交叉线
交换机uplink口 交换机uplink口 交叉线

所谓的交叉线是指:一端是568A标准,另一端是568B标准的双绞线。
直连线则指:两端都是568A或都是568B标准的双绞线。
电缆内有8根电线,分为4对,每一对就是一对双绞线,依次为:(白橙,橙);(白绿,绿);(白蓝,蓝);(白棕,棕)
568A的排线顺序从左到右依次为:白绿绿白橙白蓝白棕
568B的排线顺序从左到右依次为:白橙白绿白蓝绿白棕
其中1、2用于发送数据,3、6用于接收数据,4、5用于传输语音,7、8用于传输电源。
顺便说一下,许多朋友在做RJ45头的时候,只是保证线两端的顺序一一对应,却并未按照568A/568B的排线标准去做。这样虽能连通网络,但这种线的抗干扰性非常差,经常出现诸如传输速度慢、网络时好时坏的情况。希望大家在做网线的时候一定按照标准去做,并且根据实际的工程经验网线长度最好不小于1.5米,这对提高网络的稳定性是非常必要的!

—- 转贴结束 ——————————————————————————————————————————————-
基本上,都是两头568B的线用的多,如果pc和 pc相连,就是一头568A一头568B。还有现在大部分的端口都是智能的,尤其是DEC设备,所以和DEC设备连其实无所谓的。反正能识别。

Powered by WordPress