Python好东西(转)

最近研究了一下Python,觉得他这种问答式的界面特别适合学习编程,下面就举两个例子。
1.快速排序的算法描述
>>> def qsort(aL):
...  if aL==[]:return []
...  else:
...   smaller=[x for x in aL[1:] if x<aL[0]] #比aL[0]小的部分
...   bigger=[x for x in aL[1:] if x>=aL[0]] #比aL[0]大(或相等)的部分
...   return qsort(smaller)+[aL[0]]+qsort(bigger)
...
>>> qsort([3,4,5,1])
[1, 3, 4, 5]
>>> import random
>>> a=range(0,100)
>>> a
[0, 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, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
>>> random.shuffle(a)
>>> a
[69, 77, 17, 97, 21, 1, 44, 20, 82, 46, 59, 63, 4, 47, 38, 25, 48, 84, 72, 2, 52, 10, 31, 3, 58, 43, 9, 96, 95, 27, 0, 71, 40, 12, 76, 8, 14, 79, 53, 80, 28, 15, 91, 22, 65, 68, 86, 18, 32, 85, 55, 36, 92, 74, 50, 11, 83, 81, 7, 57, 90, 54, 87, 24, 29, 37, 61, 35, 56, 60, 88, 75, 30, 16, 13, 39, 26, 70, 93, 49, 51, 23, 41, 98, 66, 99, 89, 5, 34, 6, 94, 64, 67, 62, 78, 73, 19, 33, 42, 45]
>>> qsort(a)
[0, 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, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]

注:算法效率虽然不高,但意思很明朗。
2.模仿QQ尾巴之“记事本尾巴”
用到了的“Hook”,需要下载一个pyHook 模块
import win32ui,win32con,pyHook,pythoncom
def hookhandle(event):
    if event.KeyID==13:  #捕捉回车键(注,QQ尾巴捕捉Ctrl+Enter及单击发送按钮)
 try:
         pwin=win32ui.FindWindow('Notepad',None) #找到记事本窗口
         textbox=win32ui.FindWindowEx(pwin,None,'Edit',None) #找到编辑窗口
         buf='0x0'*1024
         oldlen=textbox.SendMessage(win32con.WM_GETTEXT,buf) #获得编辑窗口中原有的文本
         textbox.SendMessage(win32con.WM_SETTEXT,buf[0:oldlen]+'\r\nhttp://www.csdn.net') #加上个尾巴,呵呵
 except:
  pass
hm = pyHook.HookManager()  #钩子实例化
hm.KeyDown=hookhandle  #指明回调函数
hm.HookKeyboard()   #Hook键盘
pythoncom.PumpMessages()  #消息循环

当然,QQ尾巴肯定不会用动态语言写,我在这里只是为了说明python的确是一个很好的学习工具,只要你能想到原理,
那么赶紧用python验证一下吧.

转载于:https://www.cnblogs.com/flappy/archive/2007/03/06/665969.html

<< 要将Word文档换为图片,可以使用第三方库`python-docx`读取Word文件内容,并借助像Pillow这样的图像处理库生成图片。但需要注意的是直接从文本到高质量的图片并不简单(尤其是保持原始排版),通常的做法包括以下步骤: 1. 使用 `docx2txt` 或者 `python-docx` 提取 Word 文档中的文字信息。 2. 将这些文字绘制在一个空白画布上或保存成一张带有字体、颜色等样式设置后的图片。 这里提供一段示例代码演示如何初步完成此操作: ```python from PIL import Image, ImageDraw, ImageFont import docx def word_to_image(doc_path): # 加载并解析 .docx 文件 document = docx.Document(doc_path) paragraphs = [para.text for para in document.paragraphs if para.text.strip()] # 合并段落作为一行显示 (实际应用中可能需要更复杂的布局管理) text_content = "\n".join(paragraphs) font_size = 20 padding = 50 img_width = 800 line_height = int(font_size * 1.5) + padding // len(text_content.splitlines()) img_height = max(line_height * len(text_content.split('\n')) + 2*padding ,img_width//2 ) image = Image.new("RGB", (img_width,img_height), color=(255,255,255)) draw = ImageDraw.Draw(image) try: font = ImageFont.truetype('arial.ttf', size=font_size) except IOError: print("Arial 字体缺失") return None y_start = padding / 2 x_position = padding for idx,line_text in enumerate(text_content.split("\n")) : position = (x_position,y_start+idx*(line_height-padding)+random.randint(-7,+9))#添加一点随机错位效果让其看起来不那么机械式对齐 draw.multiline_text(position ,line_text,(0,0,0),spacing=-int(padding*.6),align='left',font=font) output_filename="output_word_as_img.png" image.save(output_filename,"PNG") if __name__ == '__main__': path_of_doc_file="/path/to/your/document.docx" #替换成自己的路径名及文件名即可运行测试! word_to_image(path_of_doc_file) ``` 这段程序首先定义了一个名为 "word_to_image" 的函数用于接收 DOCX 格式的文档地址参数;然后利用 Python-Docx 库逐行提取出其中包含的文字内容;接着用 Pillow 创建了一幅新的 RGB 图片,在上面按照一定规则渲染之前获得的内容字符串;最后输出结果存储至本地磁盘上的 PNG 文件之中。 给出解释: 上述过程分为两部分,首先是数据获取阶段——我们采用 python-docx 进入 Microsoft Office Word (.docx) 文件内部结构找到所有的正文块存放到列表当中去掉了空格等内容无关项之后再拼接起来形成完整连续的大段描述性的纯文本串; 其次是图形化展示环节——运用 pillow 模拟创建一块标准大小且背景色全白的新 canvas 对象实例后调用了 Draw 方法进一步指定坐标系原点开始位置处依次写明每句话的具体字形属性例如粗细程度以及填充颜料盒之类的东西直至结束为止才正式提交命令序列执行完毕并且自动命名为固定好的 Output_File_Name 变量值所指示的名字保留下来供后续查看或者分享之需.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值