从数据库中的新闻字段中获取第一个图片路径

今天给别人修改一个项目,我相这是程序员同志们最烦的事情啦,特别是在别人设计不合理,代码书写不规范的情况下,更是痛不欲生,很不幸这个项目就是一个失败中的典型,废话少说,言归正传,因为数据库设计不合理的原因,所以必须要在前台新闻字段(也就是text类型,通过新闻编辑器向里插入的html代码)取出第一个图片的图片路径,实现方法有两种,一种是可能sql的字符串函数来获取,当然还有一种最为方便、简单、快捷的方法,那就是通过.net的正则表达式。

 

方法一 sql法

因为这是个项目是修改项目,所以很多东西不能动原有的代码,所以在获取新闻字段图片的时候只有用第一种sql的方式,但这样做可大大降低查询的效率,特别是在数据量大的时候,会出现很大问题,不过不幸中的万幸是这个项目的数据量不会太多,经多次调试终于写出了一个相对比较不容易出错的sql语句:

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
select substring ( substring ( substring (( substring (( convert ( char ( 1000 ),brief)),( charindex ( ' <img ' ,( convert ( char ( 1000 ),brief)), 0 )), 1000 )), 0 , 1000 ),( charindex ( ' src= ' ,( substring (( convert ( char ( 1000 ),brief)),( charindex ( ' <img ' ,( convert ( char ( 1000 ),brief)), 0 )), 1000 )), 0 )) + 5 , 1000 ), 0 ,( charindex ( ' " ' , substring ( substring (( substring (( convert ( char ( 1000 ),brief)),( charindex ( ' <img ' ,( convert ( char ( 1000 ),brief)), 0 )), 1000 )), 0 , 1000 ),( charindex ( ' src= ' ,( substring (( convert ( char ( 1000 ),brief)),( charindex ( ' <img ' ,( convert ( char ( 1000 ),brief)), 0 )), 1000 )), 0 )) + 5 , 1000 ), 0 ))) from hotel

 

 

 写完之后一看眼睛都花了,思路是这样的:

先从新闻字段的中获取第一个"<img"标签的位置并取其后的字符串,以保证当前标签就是图片

(假如字段值是<p><img alt="" src="1.jpg"><table>……</p>,在第一次裁取之后只剩下<img alt=""  src="1.jpg"><table>……</p>),

再从取出后的字符串获取"src="标签的位置并取其后的字符串,以确定后一个字符开始就是图片的路径了

(裁取之后的内容为:1.jpg"><table>……</p>)

现在要做的就是裁掉“"”之后的字符串

(于是就得出1.jpg)

 

虽然图片是获取出来了,但我对其速度相当的不满意,在此希望高人指点一二,如何更高速有效的通过sql获取其字段的图片路径。

 

方法二:.net 正则表达式法

当然这一种方法没得说,.No1,

 

ContractedBlock.gif ExpandedBlockStart.gif 代码
 
   
// 取出图片路径
MatchCollection mc;
Regex r
= new Regex( @" <img.*?src=(?:""|')?(.*?\.(?:jpg|gif)).*? " );
mc
= r.Matches( " 这里填写你要找的HTML代码 赋值给一个字符串 " );
for ( int i = 0 ;i < mc.count;i ++ )
{
// mc[i]就是图片路径了
}

当然这个正则表达式也可能存一些或大或小的bug,希望大家多多指点。

 

转载于:https://www.cnblogs.com/xhyang110/archive/2010/05/06/1729147.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值