- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python使用pyh生成HTML文档的方法示例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
最近在项目中需要将结果导出到html中,在网上搜索的时候发现了这个库,通过官方的一些文档以及网上的博客发现它的使用还是很简单的,因此选择在项目中使用它.
在使用的时候发现在python3中有些问题,网上很多地方都没有提到,因此我在这将它的使用以及我遇到的问题和解决方案整理出来供大家参考 。
本文主要参考 pyh中文文档 。
下载的样本也是该文中提到的地址 。
常规使用 。
在使用时一般先导入模块
1
|
from
phy
import
*
|
然后可以创建一个pyh对象就像这样 。
1
|
page
=
pyh(title)
|
其中title是一个字符串,这个字符串将作为页面的标题显示,也就是说此时产生的html代码就是在头部加上一个title标签并将这个字符串作为文本值 。
然后我们可以addcss方法或者addjs方法引入外部的js文件或者css文件(调用这两个函数将在html的头部产生一个引入的代码,对于那种在body中添加style代码的我暂时没有找到什么办法) 。
然后就是创建标签对象,对应标签类的名字所与在html中的对应的名称相同,传入对象的参数就是标签中的属性,除了class属性对应的参数名称是cl外,其余的参数名称与在html中的属性一一对应。比如我们要创建一个div标签可以这样写 。
1
|
mydiv
=
div(
'测试div'
,
id
=
'div1'
, cl
=
"cls_div"
)
|
最终生成的html代码如下
1
|
<div
id
=
'div1'
class
=
'cls_div'
>测试div<
/
div>
|
将元素加入某个元素中可以使用<<符号,该符号返回的是最后被包含的符号对象。比如这样 。
1
|
div(
id
=
'div1'
) << p(
'测试'
cl
=
'p_tag'
)
|
这句代码会返回p元素对应的对象,而生成的html代码如下:
1
2
3
|
<div
id
=
'div1'
>
<p
class
=
'p_tag'
>测试<
/
p>
<
/
div>
|
当生成了合适的html文档后可以使用printout方法将其打印,也可以使用render函数返回对应的html代码,以便我们进行存盘或者做进一步处理 。
上面只是简单的做一下介绍,详细的使用方法请参看上面提到的一篇文章,这上面写的比较详细。下面来通过一个例子代码来说明我是如何处理一些出现的错误、做一些简单的扩展,并大致看看里面的源代码 。
例子 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
from
pyh
import
*
import
codecs
from
xml.sax.saxutils
import
escape
word_width
=
100
def
create_base(table_title, page):
page.addcss(
'base.css'
)
#展示信息的表
base_table
=
page << table(cl
=
'diff'
,
id
=
'difflib_chg_to0__top'
, cellspacing
=
'0'
, cellpadding
=
'0'
, rules
=
'groups'
)
for
i
in
range
(
4
):
base_table << colgroup()
#表头
t_head
=
base_table << thead()
tr_tag
=
t_head << tr()
tr_tag << th(cl
=
'diff_next'
) << br()
tr_tag << th(table_title, colspan
=
'2'
, cl
=
'diff_header'
)
t_body
=
base_table << tbody()
return
t_body
#写入一行信息
def
write_line(tr_tag, mark, data):
tr_tag << td(mark, cl
=
'diff_header'
)
tr_tag << td(data)
def
txt2html(title, table_title, ifile, ofile):
i_f
=
codecs.
open
(ifile,
'r'
,encoding
=
'utf-8'
)
lines
=
i_f.read().splitlines()
i_f.close()
page
=
pyh(title)
t_body
=
create_base(table_title, page)
lineno
=
1
for
data
in
lines:
if
len
(data) >
=
word_width:
for
i
in
range
(
len
(data)
/
/
word_width
+
1
):
sub_data
=
data[word_width
*
i:
min
(word_width
*
(i
+
1
),
len
(data)
-
1
)]
if
i
=
=
0
:
mark
=
str
(lineno)
else
:
mark
=
'>'
tr_tag
=
t_body << tr()
sub_data
=
escape(sub_data)
sub_data
=
sub_data.replace(
" "
,
" "
)
sub_data
=
sub_data.replace(
"\t"
,
" "
)
write_line(tr_tag, mark, sub_data)
else
:
tr_tag
=
t_body << tr()
data
=
escape(data)
data
=
data.replace(
" "
,
" "
)
data
=
data.replace(
"\t"
,
" "
)
write_line(tr_tag,
str
(lineno), data)
lineno
+
=
1
html
=
page.render()
o_f
=
codecs.
open
(ofile,
'w'
, encoding
=
'utf-8'
)
o_f.write(html)
o_f.close()
|
这是一个将任意文本文件转化为html文档的例子,主要是在调用txt2html函数,该函数有4个参数,页面的标题,展示文本内容的表格的标题,输入文件路径,输出文件路径 。
同时做了一些简单的处理,对原文档中的每行进行标号,同时设置一行只显示100个字符多余的进行换行,以便阅读 。
最终打开生成的html大致如下:
在python3环境下直接运行发现它报了一个错误:
在python2中存在unicode字符串和普通字符串的区别,但是在python3中所有字符串都默认是unicode的,它取消了关于python2中unicode函数,这里报错主要是这个原因,因此我们定位到报错的地方,将代码进行修改,去掉unicode函数(在python2中unicode函数需要传入一个普通字符串,因此这里我们只需要去掉unicode函数,保留原来的参数即可,对于进行字符号转化的直接注释或者改为pass即可 。
解决了unicode问题之后再次运行,又报了这样一个错误 。
定位到对应代码处,在原来的代码位置有这么一段代码
1
2
3
4
5
6
7
8
9
10
|
def
tagfactory(name):
class
f(tag):
tagname
=
name
f.__name__
=
name
return
f
thismodule
=
modules[__name__]
for
t
in
tags:
setattr
(thismodule, t, tagfactory(t))
|
从这段代码上可以知道,每当我们通过对应名称创建一个标签时,会在tags里面里面寻找到对应的标签,然后调用工厂方法生成一个对应的标签,这个工厂方法生成的其实是一个tag对象,并且所有html标签都是这个tag类,因此可以猜测如果要添加新的标签对象,那么可以通过修改tags里面的值,我们加入对应的标签值之后发现代码可以运行了,至此问题都解决了.
其实这些错误都是python2代码移植到python3环境下常见的错误,至于它的源码我没怎么看太明白,主要是它生成标签的这一块,我也不知道为什么修改了tags之后就可以运行了,python类厂的概念我还是不太明白,看来要花时间好好补一下基础内容了.
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:http://www.cnblogs.com/lanuage/p/8537047.html 。
最后此篇关于Python使用pyh生成HTML文档的方法示例的文章就讲到这里了,如果你想了解更多关于Python使用pyh生成HTML文档的方法示例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个 .sln 文件,里面有几个项目。为了简单起见,让我们称它们为... 项目A 项目B 项目C ...其中 A 是引用 B 和 C 的主要项目。我的目标是更新我的构建脚本,为 ProjectA
我安装了 Magento,我想知道如何生成完整的 API 文档,例如 http://docs.magentocommerce.com/ 上的文档是使用 phpdoc 生成的。 Magento 中是否包
我通常使用jetbrains family ide。在为函数创建文档时非常有用,只需输入 /** 如何在创建文档时创建自定义标签,例如@date标签。 最佳答案 JavaScript、Java: st
我正在尝试使用 jOpenDocument library创建文档。我已经执行了创建电子表格的示例 - 代码编译并运行正常,但当我尝试使用 Excel Office 2012 或 Google Doc
如标题。 有没有介绍HTML DOM构造的图片? 最佳答案 DOM(文档 对象模型)从文档 节点开始。它被称为“根节点”。 观察下面的树(括号中对应的nodeType): [HTMLDocument]
我喜欢 ColdFusion Builder。但我不喜欢帮助只有 CF9 文档。有什么方法可以将其更改为拥有 ColdFusion 8 文档? 最佳答案 http://livedocs.adobe.c
这个问题在这里已经有了答案: What is the consequence of this bit of javascript? (4 个答案) 关闭 9 年前。 我看到一些 jQuery 脚本嵌
我有一个 XML 文件,其中包含需要在 Word 文档中填充的数据。 我需要找到一种方法来定义一个模板,该模板可用作从 XML 文件填充数据并创建输出文档的基线。 我相信有两种方法可以做到这一点。 创
我正在尝试查找有关如何使用 AVAudioEngine 的详细文档。有谁知道我在哪里可以找到它? 我找到了这个,但与文档丰富的 UI 内容相比,它似乎非常简陋。 https://developer.a
我对 Tensorflow 文档越来越感到恼火和沮丧。我在谷歌上搜索了有关 的文档 tf.reshape 我被定向到一个通用页面,例如 here 。我想查看 tf.reshape 的详细信息,而不是整
我正在学习本教程:http://moxleystratton.com/clojure/clojure-tutorial-for-the-non-lisp-programmer 然后遇到了这个片段: u
如何在 swagger 中为对象数组编写文档。这是我的代码,但我不知道如何访问对象数组中的数据。 { "first_name":"Sam", "last_name":"Smith",
是否有针对 Javascript 的 JavaDocs 之类的东西?当我在 netbeans IDE 中按 ctrl+space 时 写javascript,指定对象的javascript文档就出来了
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 5 年前。
我需要 JavaScript 中的 heredoc 之类的东西。你对此有什么想法吗?我需要跨浏览器功能。 我发现了这个: heredoc = '\ \ \ zzz\ \
WSDL 文档是包含一系列的,可描述某个 web service 的定义的,简单的 XML 文档 WSDL 文档结构 WSDL 文档用下表这些主要的元素来描述某个 web service 的
是否有 ocropus 的文档? 我正在寻找对以下功能的解释: make_SegmentPageByRAST(): segment() RegionExtractor(): setPageLines(
这个问题在这里已经有了答案: Understanding events and event handlers in C# (13 个回答) 4年前关闭。 我正在使用 NRECO 和 ffmpeg 对视
我正在尝试访问工作服务器以与名为 Spotfire 的应用程序一起使用。我的同事把这个传给我,现在已经休息了几个星期,我对他的建议有意见。 实际上,当我通过 localhost 运行我的 Web 应用
Elm 文档没有给出示例用法,因此很难理解类型规范的含义。在几个地方,我看到“a”用作参数标识符,例如 Platform.Cmd : map : (a -> msg) -> Cmd a -> Cmd
我是一名优秀的程序员,十分优秀!