[LovPy]moin文本排版指南

根据和编辑MSN 的沟通结论,快速组织指南给美术编辑使用 ~ 注意,可使用底部的注释框随时反馈沟通!

交付和排版流程

原先编辑习惯排版流程
  1. 作者提交有排版效果的 word 文档,保证文字/图片/代码质量,以及排版的基础效果
  2. 编辑協同美术编辑,在作者排版上进行增补,沟通意见,确认几个经典章节的基准排版效果;同时完成所有文字/文法/出版校对

  3. 将原稿和 基准排版章节文档,交付专业的排版公司,使用专业排版软件进行精排

  4. 排版小样出来后,编辑核对,确认后,转交印刷厂照排付印
当前社区模式的建议流程
  1. 社区提交无排版效果的纯文本/代码/图片,保证文字/图片/代码质量;前同时提供网络版本的维基页面,以及排版建议
  2. 编辑協同美术编辑,在理解纯文本(结构化文本)/代码/图片基础上,参考维基页面(不要直接使用维基页面来排版!)完成所有文字/文法/出版校对;然后统一初排成所有章节的基准排版文档

  3. 将原稿和基准排版章节文档,交付专业的排版公司,使用专业排版软件进行精排

  4. 排版小样出来后,编辑核对,和社区共同确认后,转交印刷厂照排付印

当前SVN目录使用

所以,交付的文件以SVN仓库中的为准,在正式交付时,将提供一个版本号[changeset],作为约束,从该指定版本号检出的SVN内容是最终交付稿件!

下载URL: http://openbookproject.googlecode.com/svn/trunk/LovelyPython/

./
|-- CDays           (CDays 实例故事代码)
|   |-- cday-1      (按照章节对应分立子目录收集)
|   +-- ..
|-- KDays           (KDays 实例故事代码)
|   |-- js          (共同JS表单验证模块)
|   |-- kday1       (按照章节对应分立子目录收集)
|   +-- ..
|-- PCS             (Python Cheat Sheet ~ Python 作弊条 内容)
|   |-- pcs-0       (按照章节对应分立子目录收集)
|   +-- ..
|-- exercise        (各章练习,按照章节对应收集)
|   |-- part1-CDays (CDays 实例故事练习,按照章节对应收集)
|   |   |-- cday-1  (按照章节对应收集)
|   |   +-- ..
|   |-- part2-KDays (KDays 实例故事练习,按照章节对应收集)
|   |   +-- ..
|   |-- part3-PCS   (PCS练习,按照章节对应收集)
|   |   +-- ..
|   `-- part4-Attach(附录练习,按照章节对应收集)
|       +-- ..
`-- pages           (图书主体正文 .moin 文本目录)
    |-- 4editor     (正文无关:图书编辑参考维基页面文本)
    |-- attachments (图书主体正文 对应各章附图/文)
    `-- reST        (正文无关:图书主体正文旧 reST格式文本)

moin 文本排版

由于SVN中提供的是无排版的纯文本,所以:

但是,基于长期的图书体验,社区谨提出以下排版建议

字体建议

本着技术阅读的体验,强烈建议排版时注意技术文档的字体!

参考
建议

代码颜色

本着技术文档阅读的体验,强烈建议排版时注意代码颜色!

社区负责 文字/代码/图片 的质量,而编辑排版时,对代码更加要精确的再现,否则后果不言而喻!

   1 # coding : utf-8
   2 import os
   3 for root, dirs, files in os.walk('/media/cdrom0'):
   4   print root,dirs,files

版式/空间

本着原版图片阅读体验,强烈建议排版时注意页面的行间/页眉/页脚/页边 的设计!

建议参考 O'REILLY 图书 "MIND HACKS" 的设计对图书的各个内容块进行排版设计!

moin 内容块识别

虽然提供的是纯文本,但!其实是 MoinMoin 维基格式的结构化文本! 本身已经非常非常非常明确的将内容块的关系/结构表述清楚了!

以下给出常见的结构化文本说明

标题

维基中使用 单独行中前后的 = 进行标题/章节的聲明

= 大标题 =
== 二标题 ==
=== 三标题 ===
= 大标题 =

解析输出如下:


大标题

二标题

三标题

大标题


注意
  • 当然正文中可能有四级/五级标题的情况,但是不建议机器的照搬使用;

列表

维基中使用 * 或是 1. 以及前面的半角空格数目,來组织不同级别的列表 例:

 * 普通列表
  * 子条目
   * 再次条目
   * 再次条目
  * 子条目
 * 普通列表

 1. 数字列表
  1. 子条目
   1. 再次条目
   1. 再次条目
  1. 子条目

以上文字将解析成:

引用

维基中使用 {{{}}} 包围来声明是引用内容块!

   1 # coding : utf-8
   2 import os
   3 for root, dirs, files in os.walk('/media/cdrom0'):
   4   print root,dirs,files

表格

维基中使用 || 快速声明简单表格:

|| 表头0|| 表头1|| 表头2||
|| 表行1|| 表列1-1|| 表列1-2||
|| 表行2|| 表列2-1|| 表列2-2||

解析输出成:

表头0

表头1

表头2

表行1

表列1-1

表列1-2

表行2

表列2-1

表列2-2

注意
  • 请编辑对照维基效果,进行决定表格形式

维基中为了扩展内容的组织正式,有特殊的行为支持,称作 ~ 所有以 [[宏名称()]] 方式組織的文本都是有特殊含义的,不能直接来排版!

MoinMoin 支持很多 最常用的如下:

脚注

在正文的任意地方出现类似文字:

[[FootNote(脚注 文字,自动序号出现在页面底部)]]

将解析输出为1

注意
  • 排版时只要将 脚注序号插入正文对应处,在FootNote() 中的文字,应该排版到页面底!

包含

在正文的任意地方出现类似文字:

[[Include(ObpLovelyPython/CDay1/new)]]

含义就是在此处将 http://wiki.woodpecker.org.cn/moin/ObpLovelyPython/CDay1/new 页面的所有内容输出; 效果如下

   1 def iniCDinfo(cdrom,cdcfile):
   2     '''光盘信息.ini格式化函式
   3     @note: 直接利用 os.walk() 函式的输出信息由ConfigParser.RawConfigParser进行重组处理成 .ini 格式文本输出并记录
   4     @param cdrom: 光盘访问路径
   5     @param cdcfile: 输出的光盘信息记录文件(包含路径,绝对、相对都可以)
   6     @return: 无,直接输出成组织好的类.ini 的*.cdc 文件
   7     '''
   8     walker = {}
   9     for root, dirs, files in os.walk(cdrom):
  10         walker[root]=(dirs,files)     # 这里是个需要理解的地方
  11     cfg = rcp()
  12     cfg.add_section("Info")
  13     cfg.add_section("Comment")
  14     cfg.set("Info", 'ImagePath', cdrom)
  15     cfg.set("Info", 'Volume', cdcfile)
  16     dirs = walker.keys()
  17     i = 0
  18     for d in dirs:
  19         i+=1
  20         cfg.set("Comment", str(i),d)
  21     for p in walker:
  22         cfg.add_section(p)
  23         for f in walker[p][1]:
  24             cfg.set(p, f, os.stat("%s/%s"%(p,f)).st_size)    
  25     cfg.write(open(cdcfile,"w"))
注意
  • 末尾的细线,以及{ObpLovelyPython/CDay1/new}e 都是自动生成的提示操作链接,请不要进行排版!清除即可;-)

维基元素

为了保证维基文章有网络图书的特性,在正文的头尾有一些通用的内容元素声明,以便形成友好的阅读环境, 但是,编辑要有所识别,请不要进行排版!清除即可;-)

##language:zh
#pragma section-numbers on

||'''status'''|| 校对  || ZoomQuiet || 100% ||

[[TableOfContents]]

...

## 设计实用练习,确保体例代码可以自由扩展出各种实用应用!

...

----
::-- ZoomQuiet [[[DateTime(2007-04-13T16:17:50Z)]]]

以上都是最常见的网络内容元素,请不要进行排版!清除即可;-)

链接处理

在 行者箴言 的修订和完善,进行了体例化,请编辑看是否合适?

  1. 每条箴言 提供E文版本
  2. 每条箴言 背景+解说 构成
  3. 考虑到读者是从图书中手工输入URL,所以,提议使用tinyurl 服务,类似:

优雅型修饰

所有链接,给出原始URL,和短型URL,以方便读者输入...

~~~正文HTML~~~
The URL of ZEUUX is <a href="http://www.zeuux.org>http://www.zeuux.org</a>.Look <a href='http://www.zeuux.org/news/news.cn.html">news</a> of ZEUUX.
~~~修改后~~~
The URL of ZEUUX is http://www.zeuux.org[1]. Look news[2] of ZEUUX.

~~~文章结尾处添加~~~
[1] http://www.zeuux.org
[2] http://www.zeuux.org/news/news.cn.html


反馈 其它末尽.moin 结构化文本的聲明含义,请随时在 zeuux-press 列表沟通确认!

创建 by -- ZoomQuiet [2008-06-17 02:33:37]

  1. 脚注 文字,自动序号出现在页面底部 (1)

ObpLovelyPyEditorRule/LayoutMointext (last edited 2009-12-25 07:14:40 by localhost)