Python编程快速上手--8.9.1 扩展多重剪贴板、 8.9.2 疯狂填词、8.9.3 正则表达式查找

8.9.1 扩展多重剪贴板

扩展本章中的多重剪贴板程序,增加一个delete 命令行参数,它将从shelf 中删除一个关键字。然后添加一个delete 命令行参数,它将删除所有关键字。

#! python3
# mcb.pyw - Saves and loads pieces of text to the clipboard.
# Usage: py.exe mcb.pyw save <keyword> - Saves clipboard to keyword.
# py.exe mcb.pyw <keyword> - Loads keyword to clipboard.
# py.exe mcb.pyw list - Loads all keywords to clipboard.
# py.exe mcb.pyw delete <keyword> - delete keyword.
# py.exe mcb.pyw delete - delete list.

import shelve, pyperclip, sys
mcbShelf = shelve.open('mcb')
# save clipboard content.
if len(sys.argv) == 3 and sys.argv[1].lower() == 'save':
    mcbShelf[sys.argv[2]] = pyperclip.paste()
elif len(sys.argv) == 3 and sys.argv[1].lower() == 'delete':
    del mcbShelf[sys.argv[2]]
elif len(sys.argv) == 2:
    # List keywords and load content.
    if sys.argv[1].lower() == 'list':
        pyperclip.copy(str(list(mcbShelf.keys())))
    elif sys.argv[1] in mcbShelf:
        pyperclip.copy(mcbShelf[sys.argv[1]])
    elif sys.argv[1].lower() == 'delete':
        mcbShelf.clear() # 清空后为[] 

mcbShelf.close()

8.9.2 疯狂填词

创建一个疯狂填词(Mad Libs)程序,它将读入文本文件,并让用户在该文本文件中出现ADJECTIVE、NOUN、ADVERB 或VERB 等单词的地方,加上他们自己的文本。例如,一个文本文件(wenben.txt)可能看起来像这样:

The ADJECTIVE panda walked to the NOUN and then VERB. A nearby NOUN wasunaffected by these events.

程序将找到这些出现的单词,并提示用户取代它们。

Enter an adjective:
silly
Enter a noun:
chandelier
Enter a verb:
screamed
Enter a noun:
pickup truck

以下的文本文件将被创建:

The silly panda walked to the chandelier and then screamed. A nearby pickup truck was unaffected by these events.

import re

# read in context
wbFile = open("wenben.txt")
wbcontent = wbFile.read()
print(wbcontent)
# replace content
inputct = input("Enter an adjective:\n")
Regex = re.compile(r'ADJECTIVE?')
wbcontent = Regex.sub(inputct, wbcontent)
inputct = input("Enter a noun:\n")
Regex = re.compile(r'NOUN')
wbcontent = Regex.sub(inputct, wbcontent, 1) # 对“NOUN”仅替换一次
inputct = input("Enter a verb:\n")
Regex = re.compile(r'VERB?')
wbcontent = Regex.sub(inputct, wbcontent)
inputct = input("Enter a noun:\n")
Regex = re.compile(r'NOUN?')
wbcontent = Regex.sub(inputct, wbcontent)
print(wbcontent)
outFile = open('outfile.txt', 'w')
outFile.write(wbcontent + '\n')
outFile.close()

8.9.3 正则表达式查找

编写一个程序,打开文件夹中所有的.txt 文件,查找匹配用户提供的正则表达式的所有行。结果应该打印到屏幕上。

# 查找文件夹中所有的.txt 文件,筛选出匹配用户提供的正则表达式的所有行
import os
import re
import sys

cwd = os.getcwd()
print(cwd)
# 查找文件夹中所有的.txt 文件
match1 = re.compile(r'.*\.txt$')  # 创建匹配txt的正则
txtDirList = []  # 成功匹配
for i in os.listdir(cwd):
    if match1.search(i) is not None:  # 可以直接 if match1.search(i)
        txtDirList.append(i)
print(txtDirList)
# 根据传入的参数来匹配需要行
print(sys.argv[1])
match2 = re.compile(sys.argv[1])
for i in txtDirList:
    with open(i, 'r', encoding='utf-8') as txtFile:
        txtLineList = txtFile.readlines()
        for j in txtLineList:
            if match2.search(j):
                print(j + '\n')

https://www.cnblogs.com/wudongwei/p/9016994.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

紫霄zixiao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值