字符串统计(Python)

接收键盘任意录入,分别统计大小写字母、数字及其它字符数量,打印输出。


(笔记模板由python脚本于2024年11月02日 08:23:31创建,本篇笔记适合熟悉python字符串并懂得基本编程技法的coder翻阅)


【学习的细节是欢悦的历程】

  • Python 官网:https://www.python.org/

  • Free:大咖免费“圣经”教程《 python 完全自学教程》,不仅仅是基础那么简单……
    地址:https://lqpybook.readthedocs.io/


  自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
            —— 华罗庚


  • My CSDN主页、My HOT博、My Python 学习个人备忘录
  • 好文力荐、 老齐教室
等风来,不如追风去……


接收键盘任意录入
字符串统计
(统计大小写字母、数字及其它字符)


本文质量分:

97 97 97

本文地址: https://blog.csdn.net/m0_57158496/article/details/143445325

CSDN质量分查询入口:http://www.csdn.net/qc


目 录

  • ◆ 字符串统计
    • 1、题目描述
    • 2、解题逻辑
    • 3、 代码实现
      • 3.1 变量统计
      • 3.2 sum(列表解析)
      • 3.3 sum(生成器解析)
      • 3.4 字典统计
    • 4、ai也是经常“犯错”
      • 4.1 遗漏信息
      • 4.2 表述“不清”
    • 5、完整源码(Python)


◆ 字符串统计


  我之前也写过一篇解“字符串统计”小题的学习笔记:

  1. 练习:字符串统计(坑:f‘string‘报错)
    地址:https://blog.csdn.net/m0_57158496/article/details/121723096
    浏览阅读:5.5k
    收藏:1 


1、题目描述


  • 题目描述截屏图片
    在这里插入图片描述
    1、编写函数,接收一个字符串,分别统计大写字母、小写字母、数字和其它字符的个数,并以元组形式返回结果。在主程序调用该函数并输出。

题目来源于 CSDN 问答社区提问《字符串统计》


  • 解题代码运行效果
    在这里插入图片描述



回页目录


2、解题逻辑


  • a. 一般采用变量计数器。为每个统计项设立变量初值置0,遍历字符串时累加相应变量。

  • b. 字典key替代统计变量,用dict.get方法辅助累加其值。dict结构数据,代码更紧凑,操作更顺畅,这是一般统计数据结构的“最佳方式”。


  • ai学伴总结“我的观点”
    在这里插入图片描述



回页目录


3、 代码实现


3.1 变量统计


  • 变量统计
    在这里插入图片描述

def char_statistics(text: str) -> None:upper_count = 0lower_count = 0number_count = 0other_count = 0for char in text:if char.isupper():upper_count += 1elif char.islower():lower_count += 1elif char.isdigit():number_count += 1else:other_count += 1print(f"Upper case letters: {upper_count}")print(f"Lower case letters: {lower_count}")print(f"Numbers: {number_count}")print(f"Other characters: {other_count}")# 示例文本
sample_text = "Hello World! 12345"# 调用函数进行统计
char_statistics(sample_text)

  ai是采用的“变量输出”,如要符题,只需将统计数据“组建”成tuple对象,修改输出语句就可以。如:

# 前面代码保持不变keys = ('upper_count', 'lower_count', 'number_count', 'other_count')counter = [(k, v) for k,v in zip(keys, (upper_count, lower_count, number_count, other_count))] # 列表解析式解析成“键-值”对列表# 原print() 代码不变return tuple(counter) # 列表转换成元组返回# 示例文本
sample_text = "Hello World! 12345"# 调用函数进行统计
print(f"\n\n元组统计结果:\n{char_statistics(sample_text)}\n") # 以接收返回值的方式调用函数
  • 运行效果截屏图片
    在这里插入图片描述

3.2 sum(列表解析)


列表解析统计

upper_count = sum([1 if char.isupper() else 0 for i in text])lower_count = sum([1 if char.islower() else 0 for i in text])number_count = sum([1 if char.isdigit() else 0 for i in text])other_count = len(text) - upper_count - lower_count - number_count

3.3 sum(生成器解析)


生成器解析统计

upper_count = sum(1 for char in text if char.isupper())lower_count = sum(1 for char in text if char.islower())number_count = sum(1 for char in text if char.isdigit())other_count = len(text) - upper_count - lower_count - number_count

生成器解析,代码更简洁且少占用内存。


3.4 字典统计


  • 字典统计
    字典统计的代码脚本,请往后翻或者直接选择文章目录“完整源码”跳转。😋
    贴图



回页目录


4、ai也是经常“犯错”


  AI虽然精准,但它也跟“我们”一样,时常迷糊,时有前言不搭后语的情形。😋这是我们需要知悉的,智能的ai,不会“全对”!🧐


4.1 遗漏信息


  • 截屏图片
    在这里插入图片描述

4.2 表述“不清”


  • 截屏图片
    在这里插入图片描述



回页目录


5、完整源码(Python)

(源码较长,点此跳过源码)

#!/usr/bin/env python3def char_count(s: str) -> tuple | dict:''' 字符统计 '''counts = {} # 统计字典for char in s:if char.isupper():counts['upper'] = counts.get('upper', 0) + 1elif char.islower():counts['lower'] = counts.get('lower', 0) + 1elif char.isdigit():counts['number'] = counts.get('number', 0) + 1else:counts['other'] = counts.get('other', 0) + 1chars = tuple((k, v) for k,v in counts.items()) # 为达题目要求,特意返回统计数据元组return chars, counts # 直接返回字典是更便于明细列表输出def main() -> None:''' 主程序 '''text = input('\n\n请输入字符串:')chars, counter = char_count(text) # 调用模块函数统计字符# 分别格式化统计数据upper_str = f"大写字母:{counter.get('upper', 0):>2}个"lower_str = f"小写字母:{counter.get('lower', 0):>2}个"number_str = f"数字:{counter.get('number', 0):>2}个"other_str = f"其它字符:{counter.get('other', 0):>2}个"# 统筹输出(元组和明细)print(f"\n\n输出:\n\n统计元组:{chars}\n\n{'':-^42}\n\n{lower_str:>22}\n{upper_str:>22}\n{number_str:>24}\n{other_str:>22}\n\n{'':>16}共计{len(text)}个字符\n{'':-^42}")if __name__ == '__main__':main()

  • ai学伴点评代码
    在这里插入图片描述

低版本python解释器函数返回联合类型示例


from typing import Dict, Tuple, Uniondef char_count(s: str) -> Union[Tuple[Tuple[str, int]], Dict[str, int]]:# 函数体保持不变



回页首


上一篇:  Python中的字符串“不可改变。/可以改变?”(Python中,规定字符串是“不可变”类型,字符串方法可以“重写”字符串。Python最终让您明白,“字符串不可改变”)
下一篇: 



我的HOT博:

  本次共计收集 311 篇博文笔记信息,总阅读量43.82w。数据于2024年03月22日 00:50:22完成采集,用时6分2.71秒。阅读量不小于6.00k的有 7 7 7篇。

  • 001
    标题:让QQ群昵称色变的神奇代码
    (浏览阅读 5.9w )
    地址:https://blog.csdn.net/m0_57158496/article/details/122566500
    点赞:25 收藏:86 评论:17
    摘要:让QQ昵称色变的神奇代码。
    首发:2022-01-18 19:15:08
    最后编辑:2022-01-20 07:56:47

  • 002
    标题:Python列表(list)反序(降序)的7种实现方式
    (浏览阅读 1.1w )
    地址:https://blog.csdn.net/m0_57158496/article/details/128271700
    点赞:8 收藏:35 评论:8
    摘要:Python列表(list)反序(降序)的实现方式:原址反序,list.reverse()、list.sort();遍历,全数组遍历、1/2数组遍历;新生成列表,resersed()、sorted()、负步长切片[::-1]。
    首发:2022-12-11 23:54:15
    最后编辑:2023-03-20 18:13:55

  • 003
    标题:pandas 数据类型之 DataFrame
    (浏览阅读 9.7k )
    地址:https://blog.csdn.net/m0_57158496/article/details/124525814
    点赞:7 收藏:36 
    摘要:pandas 数据类型之 DataFrame_panda dataframe。
    首发:2022-05-01 13:20:17
    最后编辑:2022-05-08 08:46:13

  • 004
    标题:个人信息提取(字符串)
    (浏览阅读 8.2k )
    地址:https://blog.csdn.net/m0_57158496/article/details/124244618
    点赞:2 收藏:15 
    摘要:个人信息提取(字符串)_个人信息提取python。
    首发:2022-04-18 11:07:12
    最后编辑:2022-04-20 13:17:54

  • 005
    标题:Python字符串居中显示
    (浏览阅读 7.6k )
    地址:https://blog.csdn.net/m0_57158496/article/details/122163023
    评论:1

  • 006
    标题:罗马数字转换器|罗马数字生成器
    (浏览阅读 7.5k )
    地址:https://blog.csdn.net/m0_57158496/article/details/122592047
    摘要:罗马数字转换器|生成器。
    首发:2022-01-19 23:26:42
    最后编辑:2022-01-21 18:37:46

  • 007
    标题:回车符、换行符和回车换行符
    (浏览阅读 6.0k )
    地址:https://blog.csdn.net/m0_57158496/article/details/123109488
    点赞:2 收藏:3 
    摘要:回车符、换行符和回车换行符_命令行回车符。
    首发:2022-02-24 13:10:02
    最后编辑:2022-02-25 20:07:40


推荐条件 阅读量突破6.00k
(更多热博,请点击蓝色文字跳转翻阅)

  • 截屏图片
    在这里插入图片描述
      (此文涉及ChatPT,曾被csdn多次下架,前几日又因新发笔记被误杀而落马。躺“未过审”还不如回收站,回收站还不如永久不见。😪值此年底清扫,果断移除。留此截图,以识“曾经”。2023-12-31)



回页首


老齐漫画头像

精品文章:

  • 好文力荐:齐伟书稿 《python 完全自学教程》 Free连载(已完稿并集结成书,还有PDF版本百度网盘永久分享,点击跳转免费🆓下载。)
  • OPP三大特性:封装中的property
  • 通过内置对象理解python'
  • 正则表达式
  • python中“*”的作用
  • Python 完全自学手册
  • 海象运算符
  • Python中的 `!=`与`is not`不同
  • 学习编程的正确方法

来源:老齐教室


◆ Python 入门指南【Python 3.6.3】


好文力荐:

  • 全栈领域优质创作者——[寒佬](还是国内某高校学生)博文“非技术文—关于英语和如何正确的提问”,“英语”和“会提问”是编程学习的两大利器。
  • 【8大编程语言的适用领域】先别着急选语言学编程,先看它们能干嘛
  • 靠谱程序员的好习惯
  • 大佬帅地的优质好文“函数功能、结束条件、函数等价式”三大要素让您认清递归

CSDN实用技巧博文:

  • 8个好用到爆的Python实用技巧
  • python忽略警告
  • Python代码编写规范
  • Python的docstring规范(说明文档的规范写法)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/58963.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[代码随想录打卡]Day2:209.长度最小的子数组 59.螺旋矩阵II 区间和 开发商购买土地 总结

双指针:快慢指针、对撞指针、滑动窗口。相关博客:双指针算法详解(快慢指针、对撞指针、滑动窗口) 209.长度最小的子数组 题目:给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于…

Vue3的router和Vuex的学习笔记整理

一、路由的基本搭建 1、安装 npm install vue-router --registryhttps://registry.npmmirror.com 2、配置路由模块 第一步:src/router/index.js创建文件 第二步:在src/view下面创建两个vue文件,一个叫Home.vue和About.vue 第三步&#x…

探索React源码:React Diff

本篇文章我们来了解一下Diff算法的实现过程。 相关概念 React中的各种节点 假设当前存在一个DOM节点,触发了一次更新,那么在协调的过程中,会有四种节点和该节点相关联: 该DOM节点本身。 workInProgress fiber,更新过程…

安装fpm,解决*.deb=> *.rpm

要从生成 .deb 包转换为 .rpm 包,可以按照以下步骤修改打包脚本 1. 使用 fpm 工具 fpm 是一个强大的跨平台打包工具,可以将 .deb 包重新打包成 .rpm,也可以直接从源文件打包成 .rpm。 安装 fpm sudo apt-get install ruby-dev sudo gem in…

【stm32】RTC时钟的介绍与使用

RTC时钟的介绍与使用 一、时间戳1、Unix时间戳2、UTC/GMT3、时间戳转换 二、BKP简介及代码编写1、BKP简介2、BKP基本结构3、BKP库函数介绍:4、程序编写: 三、RTC简介及代码编写1、RTC简介2、RTC框图2、RTC基本结构3、RTC相关库函数介绍:4、程…

深入理解Transformer中的位置编码

1 位置编码的作用 由于注意力的作用机制,不论输入序列的顺序如何,输出结果都是一样的。 也就是丢失了位置信息。 但是对于语言模型, 我们都知道顺序是很重要的, 所以需要对输入序列额外注入位置信息。 2 位置编码方式 Transfor…

使用PostgreSQL进行高效数据管理

💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 使用PostgreSQL进行高效数据管理 PostgreSQL简介 安装PostgreSQL 在Ubuntu上安装PostgreSQL 在CentOS上安装PostgreSQL 在macOS上…

Git - 两种方式撤销已提交到远端仓库的记录并删除提交记录

文章目录 命令行方式附 命令行方式 确定要撤销的提交记录 首先,使用以下命令查看提交历史: git log找到想撤销的提交记录的哈希值(SHA) ,比如9c9c98d6f7f28c41d971f8efd51ed31f9720792c 撤销提交记录 根据需求选择以下…

vscode markdown-image 图片粘贴自动上传到本地目录设置

.vscode/settings.json文件内容 {"markdown-image.base.fileNameFormat": "${hash}-${YY}${MM}${DD}-${HH}${mm}${ss}","markdown-image.local.path": "./images","markdown-image.base.uploadMethod": "Local",…

Linux入门-基础指令和权限

1.压缩打包 1.1压缩是什么 压缩是通过特定的算法,使文件减小体积,从而达到节省空间的目的。 1.2.为什么要压缩 a.压缩将文件大小减小,在本地可能不太明显,但是在网络传输中,减小了网络传输的成本。 b.将多个文件压…

大数据新视界 -- 大数据大厂之 Impala 性能优化:解锁大数据分析的速度密码(上)(1/30)

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

docker pull 拉取镜像失败,使用Docker离线包

1、登录并注册Github,然后在Github中搜索并打开“wukongdaily/DockerTarBuilder” 项目,在该项目主页点击“Fork”。 然后点 “Create Fork”,将项目创建到自己的Github主页。 2、接着在自己创建过来的这个项目中点击“Actions” 3、然后…

HTTP和HTTPS到底啥区别?不只是差一个“S”这么简单.....

在信息时代,互联网已经成为人们生活中不可或缺的一部分。我们每天浏览网页、发送邮件、进行网络购物,都离不开网络数据的传输。 而保障这些数据在传输过程中的安全,就显得尤为重要。 HTTP和HTTPS作为两种应用层协议,在网络数据传…

微服务设计模式 - 发布订阅模式(Publisher Subscriber Pattern)

微服务设计模式 - 发布订阅模式(Publisher Subscriber Pattern) 定义 发布-订阅模式(Publisher-Subscriber Pattern)是一种常见的设计模式,被广泛用于云计算和分布式系统中,以实现松散耦合的组件间通信。发…

0xGame 2024 [Week 4] Jenkins

1.前言 由于好久没做web题了,所以今天来尝试来做一波web题,仅供刷题记录。 2.题目 这个给的提示对于小白来说实在是友好的过劲。 3.分析 上网搜到一个关于Jenkins的历史漏洞,下面链接可供参考 https://blog.csdn.net/2301_80127209/arti…

yolov8训练及测试(ubuntu18.04、tensorrt、ros)

1 数据集制作 1.1标注数据 Linux/Ubuntu/Mac 至少需要 Python 2.6 (推荐使用 Python 3 或更高版本 及 PyQt5) Ubuntu Linux (Python 3 Qt5) git clone https://gitcode.com/gh_mirrors/la/labelImg.git sudo apt-get install pyqt5-dev-tools cd lab…

Nginx 反向代理(解决跨域)

文章目录 前言一、同源策略二、跨域是什么?三、Nginx解决跨域1.前端示例代码2.说明 四、nginx反向代理配置五、启动nginx六、最终效果总结 前言 Nginx反向代理解决跨域 一、同源策略 定义:同源策略(Same-Origin Policy)是指浏览…

ssm《数据库系统原理》课程平台的设计与实现+vue

系统包含:源码论文 所用技术:SpringBootVueSSMMybatisMysql 免费提供给大家参考或者学习,获取源码看文章最下面 需要定制看文章最下面 目 录 目 录 I 摘 要 III ABSTRACT IV 1 绪论 1 1.1 课题背景 1 1.2 研究现状 1 1.3 研究内容…

多渠道流量获取策略提升网站访问量的有效方法

内容概要 在当今数字时代,企业面临着越来越激烈的竞争,流量获取变得极为重要。多渠道流量获取不仅可以增加网站的访问量,还能够有效提升品牌的知名度和影响力。通过整合多种渠道,企业能够更好地触达目标受众,实现精准…

kafka实时返回浏览数据

在安装完kafka(Docker安装kafka_docker 部署kafka-CSDN博客),查看容器是否启动: docker ps | grep -E kafka|zookeeper 再用python开启服务 from fastapi import FastAPI, Request from kafka import KafkaProducer import kafka import json import …