- 浏览: 579518 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (200)
- html css (6)
- javascript (11)
- php (6)
- java基础 (18)
- mysql (8)
- ssh (7)
- linux (21)
- 杂想 (1)
- 搜索引擎 (2)
- linux-shell (2)
- perl (61)
- 单元测试 (1)
- jquery (1)
- xml (1)
- 求职招聘 (1)
- 其他 (2)
- 项目工具 (2)
- maven (10)
- ant (1)
- eclipse (3)
- windows (4)
- java (8)
- jsp (1)
- c c++ (7)
- java-web (3)
- 汇编 (1)
- 正则表达式 (2)
- 网络 (1)
- 路由 (1)
- ip (1)
- 测试驱动开发 (1)
- tdd (1)
- vim (1)
- powermock (1)
- junit (1)
- spring (1)
- spring security (1)
- httpclient (1)
- sql (1)
- sqlserver (2)
- 存储过程 (1)
- apache (1)
- Nexus (1)
- 金融 (1)
- clojure (4)
- 函数式编程 (3)
- 工作 (1)
- git (2)
- java 并发 (1)
- python (1)
- java netty proxy (1)
- scala (1)
最新评论
-
springmvc-freemarker:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
eclipse 配置maven web项目 -
zk1878:
huzhenyu 写道楼主很用心,讲得十分清楚,非常实用!呵呵 ...
eclipse 配置maven web项目 -
huzhenyu:
楼主很用心,讲得十分清楚,非常实用!
eclipse 配置maven web项目 -
宋建勇:
不错,对CountDownLatch了解加深了!
java 多线程 CountDownLatch用法 -
zk1878:
必须的。。。。
perl下载图片
perl解析html, 比较常用的模块是 HTML::TreeBuilder,该模块将html字符转化dom树,方便操作
一个dom元素对应 一个HTML::Element对象,dom的
属性方法都定义在该类中,以下是代码
# 一个dom元素,比较重要的属性,方法 # attr: $e->attr('id') 返回标签的某个属性值 # text: $e->as_text 返回标签包裹的内容,如<a>click me</a> 返回的是 click me # html: $e->as_HTML 返回该元素的html文本 # tagname: $e->tag() , 返回标签名,如a,div, 小写形式 # parent node: $e->parent , 返回父节点 # children node: $e->content_list() , 返回所有子节点,只是直接子节点 use HTML::TreeBuilder; @d=<DATA>; $html = join "",@d; #print get_elements_by_attr_regex($html, 'id', qr/^\d+$/)->as_HTML; # @elist = get_elements($html,'table','id',qr/\d+/); # print $elist[0]->as_HTML; $table = get_element_by_id($html, 'table1'); @children = $table->content_list(); foreach $child (@children){ print "child tag:",$child->tag(), "\n"; } #function defined........................ #$html: a html content #$attr: attribute name #$attr_regex: a pattern of attr value sub get_elements_by_attr_regex{ my ($html, $attr, $attr_regex) = @_; my $tree = new HTML::TreeBuilder; $tree->parse_content($html); my @list = $tree->look_down($attr, $attr_regex); return @list; } #$html: a html content #$idvalue: id value # sub get_element_by_id{ my ($html, $idvalue) =@_; my $tree = new HTML::TreeBuilder; $tree->parse_content($html); my @list = $tree->look_down('id',$idvalue); die "not unique element by id:$idvalue" if scalar(@list) != 1; return $list[0]; } #$html: a html content #$tagname: tag name # sub get_elements_by_tag_name{ my ($html, $tagname) =@_; my $tree = new HTML::TreeBuilder; $tree->parse_content($html); return $tree->find_by_tag_name($tagname); } #$html: a html string #$tag: tag name #$attr: attr name #$attr_regex: attr value pattern sub get_elements{ my ($html, $tag, $attr, $attr_regex) = @_; my @list = get_elements_by_attr_regex($html, $attr, $attr_regex); $tag = lc $tag; @list = grep $_->tag() eq $tag, @list; return @list; } __DATA__ <table id="table1" border="1" cellspacing="0" cellpadding="6"> <tr><td><a href="x">x text</a></td><td><a href="y">y</a></td></tr> <tr><td id='1s'>1</td><td >2</td></tr> </table>
发表评论
-
perl http模块总结
2013-04-04 23:51 5780perl发送http请求主要有 LWP,UserAgent ... -
perl json
2013-04-03 20:51 4117http://search.cpan.org/~makam ... -
perl xml json
2012-09-14 19:52 1292use XML::XML2JSON; ... -
perl源文件编码类型导致乱码问题
2012-09-11 09:28 2313$str = '中国'; chdir 'E:\jo ... -
perl多进程示例
2012-08-17 15:33 1935以下例子,在主进程生成3个子进程,然后再收割每个子进程,防 ... -
一段实用的perl脚本
2012-08-15 20:53 2361下面的脚本实现了在命令行直接执行perl语句或是执行 ... -
perl发送http请求,easy之极
2012-08-09 23:21 15988perl 发送http 非常之简单,发送get请求 只一 ... -
perl 操作mysql
2012-04-27 07:57 1183use DBI; @driver_names = ... -
Perl 中的线程
2012-03-31 22:19 1478原文:http://www.ibm.com/developer ... -
perl smtp 发送邮件
2012-03-20 23:44 4987原文:http://blog.chinaunix.net/ui ... -
perl开启并关闭w32进程
2012-03-05 16:31 1980perl是个很强大的脚本语言,cpan包罗万象的 ... -
perl发送http请求
2012-02-16 17:51 5205下面是一段perl发送http请求的代码,设置了请求头,表单参 ... -
perl对windows的进程的一些常用操作
2012-02-16 17:52 20611、获取所有正在运行的进程,用到了cpan的Win32::Pr ... -
perl查看已经安装的模块
2012-02-16 17:53 1384use ExtUtils::Installed; my ... -
在Perl调用C/C++代码/动态链接库
2012-02-10 17:46 6412原文http://manew.org/?p=62 perl想 ... -
perl 剪贴板操作
2012-02-09 14:05 1660以下代码设置剪贴板内容为 hello world,然后读取剪贴 ... -
perl 文件目录的创建删除拷贝
2012-01-11 18:03 5272以下三个是核心包提供的 1 unlink @files ... -
perl正则表达式中该注意的一个问题
2011-12-29 00:06 1208请看以下例子 代码1 $a='abc123EEE11 ... -
perl 目录遍历
2011-12-16 10:27 2383使用perl的 File::Find模块,目录遍历将会很简单, ... -
perl下载图片
2011-11-02 12:21 1866use LWP::Simple; my $url= ...
相关推荐
Perl CGI编程涉及到的知识点广泛,主要包括以下几个方面: 1. **Perl语言基础**:在学习Perl CGI之前,需要掌握Perl的基本语法、数据类型、控制结构、函数等。例如,了解如何声明变量、字符串操作、数组和哈希的...
- **变量操作**:通过几个练习了解Perl中的变量类型和使用方法。 **3.2 HTTP与浏览器通信** - **URI**:理解统一资源标识符的构成。 - **请求网页**:介绍用户通过浏览器向服务器发送请求的过程。 - **TCP/IP协议*...
在Perl中编写CGI程序涉及以下几个关键知识点: 1. **环境变量**:CGI程序通过一系列预定义的环境变量获取来自Web服务器的信息,如`REQUEST_METHOD`(GET或POST请求)、`QUERY_STRING`(URL中的查询字符串)和`...
Maypole将请求处理过程分为几个阶段,每个阶段都有特定的任务。 **4.5 BuySpy实现** - **4.5.1 组件和模版** BuySpy是一个具体的Maypole应用实例。 - **4.5.2 ASP到模版工具箱** ASP(Active Server Pages)是...
- 学习Perl基础,了解其语法和常用模块,如LWP::UserAgent(用于HTTP请求)和HTML::Parser(用于解析HTML)。 - 研究网络爬虫的基本原理和编写技巧,了解如何处理反爬机制和数据提取。 - 学习HTML和CSS,以便正确...
其语法吸收了C语言、Java和Perl的特点,易于学习且功能强大,支持多种数据库接口。 - **发展历程**:PHP最初由Rasmus Lerdorf在1995年创建,随着版本的不断更新和完善,PHP逐渐成为一种成熟的、面向对象的编程语言。...
### 常用的网页格式文件 随着互联网技术的发展,网页作为信息传递的重要载体,其格式也变得多样化。本文将详细介绍几种常见的网页格式文件及其特点。 #### 一、静态网页 1. **HTML (HyperText Markup Language)**...
对于初学者,这是一个很好的学习项目,可以从以下几个方面入手: 1. 了解PHP基础语法和常用函数。 2. 学习如何连接和操作MySQL数据库。 3. 理解MVC架构,分析源码中的模型、视图和控制器。 4. 探究PHP生成静态页面的...
与Java和Perl不同,你不必把头埋进100多页的文档中努力学习才可以写出一个象样的程序。只要了解一些基本的语法和语言特色,你就可以开始你的PHP编码之旅了。之后你在编码过程中如果遇到了什么麻烦,还可以再去翻阅...
ereg、preg_match、ereg_replace、preg_replace 是 PHP 中四个常用的正则表达式函数。ereg 函数使用 POSIX 风格的正则表达式,而 preg_match 函数使用 Perl 风格的正则表达式。ereg 函数已经废弃,不推荐使用。preg_...
BeautifulSoup是Python语言中一个常用的库,用于解析HTML和XML文档,它通过查找、导航、修改分析树等方式轻松处理文档。FindAll()是BeautifulSoup库中非常方便的一个函数,用于找出文档中符合特定条件的所有标签,极...
本文将详细介绍Bernese 5.0在Windows XP系统下的安装方法,并对其程序结构、文件结构以及数据处理流程进行深入解析。 #### 二、Bernese5.0软件的安装 ##### 1. 安装要求 - **硬件要求**:Bernese 5.0对硬件的要求...
JavaScript采用的是Perl语言正则表达式语法的一个相当完整的子集. 正则表达式的模式规范是由一系列字符构成的.大多数字符(包括所有字母数字字符)描述的都是按照字面意思进行匹配的字符.这样说来,正则表达式/java/...
这个命令的意思是让xscanner扫描服务器211.100.8.87的开放端口,扫描器不会对65535个端口全部进行扫描(太慢),它只会检测网络上最常用的几百个端口,而且每一个端口对应的网络服务在扫描器中都已经做过定义,从...
- 如果你想学习WAP开发,可以从以下几个方面入手: - **基础知识**:了解HTTP、TCP/IP等相关网络协议的基本原理。 - **WAP技术**:深入学习WAP协议的具体细节,包括WML(Wireless Markup Language)、WMLScript等...
Pattern的split方法,两个参数... 396 拓展示例... 397 为Image Tag添加宽度和高度属性... 397 对于每个Matcher,使用多个Pattern校验HTML. 399 解析CSV文档... 401 Java版本差异... 401 1.4.2和1.5.0之间的...
常用的编程工具包括Perl、C和Visual Basic等。微软的IIS(Internet Information Server)服务器支持CGI,能够根据客户端请求执行相应的应用程序。然而,CGI程序每次都需要重新加载,当并发用户数量增加时,会显著...
其工作原理主要包括以下几个方面: - **解析HTML**:读取HTML文件,构建DOM树。 - **渲染页面**:根据CSS样式和DOM树绘制页面。 - **执行JavaScript**:解析和执行JavaScript代码,实现动态效果和与服务器通信。 #...
- **PHP常用工具和数据库常用工具**:列举了几款流行的PHP开发工具如Zend Studio、PHPedit、EditPlus2等,以及MySQL数据库管理工具如MySQL Administrator,这些工具可提高开发效率和数据库操作的便利性。...