当前位置: 首页 > news >正文

python的字符串处理

需求:
编写一个程序,输入一段英文句子,统计每个单词的长度,并将单词按照长度从短到长排序。

程序逻辑框图
1、用户输入一句英文句子。
2、对输入的句子进行预处理(去空格并分割为单词列表)。
3、统计每个单词的长度。
4、按照单词长度排序。
5、输出结果。

代码实现:

def process_sentence(sentence):"""处理英文句子,统计每个单词长度并按照长度排序。参数:sentence (str): 输入的英文句子返回:list: 按长度排序的单词列表,每个元素为 (单词, 长度)"""# 去除两端多余空格并按空格分割句子为单词words = sentence.strip().split()# 生成包含单词及其长度的元组列表word_lengths = [(word, len(word)) for word in words]# 按长度排序单词sorted_words = sorted(word_lengths, key=lambda x: x[1])return sorted_words# 测试
if __name__ == "__main__":# 用户输入句子input_sentence = input("请输入一个英文句子: ")# 调用函数处理句子result = process_sentence(input_sentence)# 输出结果print("\n每个单词及其长度(按长度排序):")for word, length in result:print(f"单词: {word}, 长度: {length}")

使用类(class)实现该功能:

程序逻辑框图
类定义:
init: 初始化对象,存储输入句子。
process_sentence: 分割句子并生成单词和长度的元组列表。
sort_by_length: 按单词长度对元组列表排序。
测试代码:
1、用户输入句子。
2、创建 SentenceProcessor 类实例。
3、调用方法获取排序后的单词及长度。
4、输出结果。

代码实现:

class SentenceProcessor:"""英文句子处理类,用于统计单词长度并按照长度排序。"""def __init__(self, sentence):"""初始化对象,存储句子。参数:sentence (str): 输入的英文句子"""self.sentence = sentence.strip()self.words = []def process_sentence(self):"""处理句子,将单词及其长度存储为列表。返回:list: 包含 (单词, 长度) 的元组列表"""# 分割句子为单词self.words = self.sentence.split()# 生成包含单词和长度的元组列表return [(word, len(word)) for word in self.words]def sort_by_length(self):"""按单词长度排序。返回:list: 按长度排序的 (单词, 长度) 的元组列表"""# 调用 process_sentence 方法生成元组word_lengths = self.process_sentence()# 按长度排序return sorted(word_lengths, key=lambda x: x[1])# 测试
if __name__ == "__main__":# 用户输入句子input_sentence = input("请输入一个英文句子: ")# 创建处理器对象processor = SentenceProcessor(input_sentence)# 获取排序结果sorted_words = processor.sort_by_length()# 输出结果print("\n每个单词及其长度(按长度排序):")for word, length in sorted_words:print(f"单词: {word}, 长度: {length}")
http://www.lryc.cn/news/493221.html

相关文章:

  • 【线程】Java多线程代码案例(2)
  • 虚拟机之间复制文件
  • 如何为 XFS 文件系统的 /dev/centos/root 增加 800G 空间
  • Java算法OJ(11)双指针练习
  • 44.扫雷第二部分、放置随机的雷,扫雷,炸死或成功 C语言
  • 大语言模型LLM的微调代码详解
  • 钉钉与企业微信机器人:助力网站定时任务高效实现
  • 自然语言处理工具-广告配音工具用于语音合成助手/自媒体配音/广告配音/文本朗读-已经解锁了 全功能的 apk包
  • 深入解析注意力机制
  • Unity图形学之雾Fog
  • 【大数据学习 | Spark-Core】详解Spark的Shuffle阶段
  • 如何启动 Docker 服务:全面指南
  • 使用client-go在命令空间test里面对pod进行操作
  • Linux中网络文件系统nfs使用
  • 气膜建筑:打造全天候安全作业空间,提升工程建设效率—轻空间
  • 【HarmonyOS学习日志(10)】一次开发,多端部署之功能级一多开发,工程级一多开发
  • dmdba用户资源限制ulimit -a 部分配置未生效
  • 【Code First】.NET开源 ORM 框架 SqlSugar 系列
  • 如何在谷歌浏览器中切换DNS服务器
  • Spring Cloud Stream实现数据流处理
  • 列表上移下移功能实现
  • 升级智享 AI 直播三代:领航原生直播驶向自动化运营新航道
  • Llmcad: Fast and scalable on-device large language model inference
  • Hbase2.2.7集群部署
  • 【青牛科技】D1671 75Ω 带4级低通滤波的单通道视频放大电 路芯片介绍
  • [NeurIPS 2022] Leveraging Inter-Layer Dependency for Post-Training Quantization
  • ubuntu+ROS推视频流至网络
  • PHP 去掉特殊不可见字符 “\u200e“
  • 深度学习—BP算法梯度下降及优化方法Day37
  • elasticsearch8.16 docker-compose 多机器集群安装