如果你有足够长时间做某事,一定会更擅长。

知识点:

  • 计算机基础
  • 变量
  • 运算符
  • if语句
  • for-in循环
  • 函数
  • 列表、元组、字典、字符串、集合

ascii、unicode、utf-8、gbk 区别

  1. ASCII主要用于显示现代英语和其他西欧语言,规定了128个字符的编码,使用一个字节编码,不支持中文;
  2. GBK编码是对GB2312的扩展,完全兼容GB2312。采用双字节编码方案,剔出xx7F码位,共23940个码位,共收录汉字和图形符号21886个;
  3. Unicode为世界上所有字符都分配了一个唯一的数字编号,采用4个字节编码,意味着一个英文字符本来只需要1个字节,而在Unicode编码体系下需要4个字节,其余3个字节为空,这就导致资源的浪费;
  4. UTF-8是一种针对Unicode的可变长度字符编码,又称万国码,用16个字节编码UNICODE字符;

输入年份判断是不是闰年。

  1. year = int(input('请输入年份: '))
  2. is_leap = (year % 4 == 0 and year % 100 != 0 or
  3. year % 400 == 0)
  4. print(is_leap)

百分制成绩转等级制

百分制成绩转等级制成绩
90分以上--> A,80分~89分--> B,70分~79分--> C,60分~69分 --> D,60分以下--> E

  1. score = float(input('请输入成绩: '))
  2. if score >= 90:
  3. grade = 'A'
  4. elif score >= 80:
  5. grade = 'B'
  6. elif score >= 70:
  7. grade = 'C'
  8. elif score >= 60:
  9. grade = 'D'
  10. else:
  11. grade = 'E'
  12. print('对应的等级是:', grade)

用for循环实现1~100求和

  1. sum = 0
  2. for x in range(101):
  3. sum += x
  4. print(sum)

输入一个数判断是不是素数。

  1. from math import sqrt
  2. num = int(input('请输入一个正整数: '))
  3. end = int(sqrt(num))
  4. is_prime = True
  5. for x in range(2, end + 1):
  6. if num % x == 0:
  7. is_prime = False
  8. break
  9. if is_prime and num != 1:
  10. print('%d是素数' % num)
  11. else:
  12. print('%d不是素数' % num)

输入两个正整数计算最大公约数和最小公倍数

  1. x = int(input('x = '))
  2. y = int(input('y = '))
  3. if x > y:
  4. x, y = y, x
  5. for factor in range(x, 0, -1):
  6. if x % factor == 0 and y % factor == 0:
  7. print('%d和%d的最大公约数是%d' % (x, y, factor))
  8. print('%d和%d的最小公倍数是%d' % (x, y, x * y // factor))
  9. break

实现计算求最大公约数和最小公倍数的函数

  1. def gcd(x, y):
  2. (x, y) = (y, x) if x > y else (x, y)
  3. for factor in range(x, 0, -1):
  4. if x % factor == 0 and y % factor == 0:
  5. return factor
  6. def lcm(x, y):
  7. return x * y // gcd(x, y)

实现判断一个数是不是回文数的函数

  1. def is_palindrome(num):
  2. temp = num
  3. total = 0
  4. while temp > 0:
  5. total = total * 10 + temp % 10
  6. temp //= 10
  7. return total == num

实现判断一个数是不是素数的函数

  1. def is_prime(num):
  2. for factor in range(2, num):
  3. if num % factor == 0:
  4. return False
  5. return True if num != 1 else False

写一个程序判断输入的正整数是不是回文素数

  1. if __name__ == '__main__':
  2. num = int(input('请输入正整数: '))
  3. if is_palindrome(num) and is_prime(num):
  4. print('%d是回文素数' % num)

在屏幕上显示跑马灯文字

  1. import os
  2. import time
  3. def main():
  4. content = '北京欢迎你为你开天辟地…………'
  5. while True:
  6. # 清理屏幕上的输出
  7. os.system('cls') # os.system('clear')
  8. print(content)
  9. # 休眠200毫秒
  10. time.sleep(0.2)
  11. content = content[1:] + content[0]
  12. if __name__ == '__main__':
  13. main()

设计一个函数产生指定长度的验证码,验证码由大小写字母和数字构成

  1. import random
  2. def generate_code(code_len=4):
  3. """
  4. 生成指定长度的验证码
  5. :param code_len: 验证码的长度(默认4个字符)
  6. :return: 由大小写英文字母和数字构成的随机验证码
  7. """
  8. all_chars = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
  9. last_pos = len(all_chars) - 1
  10. code = ''
  11. for _ in range(code_len):
  12. index = random.randint(0, last_pos)
  13. code += all_chars[index]
  14. return code

计算指定的年月日是这一年的第几天

  1. def is_leap_year(year):
  2. """
  3. 判断指定的年份是不是闰年
  4. :param year: 年份
  5. :return: 闰年返回True平年返回False
  6. """
  7. return year % 4 == 0 and year % 100 != 0 or year % 400 == 0
  8. def which_day(year, month, date):
  9. """
  10. 计算传入的日期是这一年的第几天
  11. :param year: 年
  12. :param month: 月
  13. :param date: 日
  14. :return: 第几天
  15. """
  16. days_of_month = [
  17. [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
  18. [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
  19. ][is_leap_year(year)]
  20. total = 0
  21. for index in range(month - 1):
  22. total += days_of_month[index]
  23. return total + date
  24. def main():
  25. print(which_day(1980, 11, 28))
  26. print(which_day(1981, 12, 31))
  27. print(which_day(2018, 1, 1))
  28. print(which_day(2016, 3, 1))
  29. if __name__ == '__main__':
  30. main()

打印杨辉三角

  1. def main():
  2. num = int(input('Number of rows: '))
  3. yh = [[]] * num
  4. for row in range(len(yh)):
  5. yh[row] = [None] * (row + 1)
  6. for col in range(len(yh[row])):
  7. if col == 0 or col == row:
  8. yh[row][col] = 1
  9. else:
  10. yh[row][col] = yh[row - 1][col] + yh[row - 1][col - 1]
  11. print(yh[row][col], end='\t')
  12. print()
  13. if __name__ == '__main__':
  14. main()

双色球选号

  1. from random import randrange, randint, sample
  2. def display(balls):
  3. """
  4. 输出列表中的双色球号码
  5. """
  6. for index, ball in enumerate(balls):
  7. if index == len(balls) - 1:
  8. print('|', end=' ')
  9. print('%02d' % ball, end=' ')
  10. print()
  11. def random_select():
  12. """
  13. 随机选择一组号码
  14. """
  15. red_balls = [x for x in range(1, 34)]
  16. selected_balls = []
  17. selected_balls = sample(red_balls, 6)
  18. selected_balls.sort()
  19. selected_balls.append(randint(1, 16))
  20. return selected_balls
  21. def main():
  22. n = int(input('机选几注: '))
  23. for _ in range(n):
  24. display(random_select())
  25. if __name__ == '__main__':
  26. main()

写函数,计算传入字符串中的数字、字母、空格以及其他的个数,并返回结果

  1. def func(s):
  2. dict = {'num': 0, 'alpha': 0, 'space': 0, 'other': 0}
  3. for i in s:
  4. if i.isdigit():
  5. dict['num'] += 1
  6. elif i.isalpha():
  7. dict['alpha'] += 1
  8. elif i.isspace():
  9. dict['space'] += 1
  10. else:
  11. dict['other'] += 1
  12. return dict
  13. a = input('请输入字符串:')
  14. print(func(a))

写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容,并返回结果

  1. def func(s):
  2. if type(s) is str and s:
  3. for i in s:
  4. if i == ' ':
  5. return True
  6. elif type(s) is list or type(s) is tuple:
  7. for i in s:
  8. if not i:
  9. return True
  10. elif not s:
  11. return True
  12. a = input('请传入对象(字符串、列表、元组):')
  13. print(func(a))

Python基础练级攻略:day01的更多相关文章

  1. Python 自动化测试全攻略:五种自动化测试模型实战详解

    随着移动互联网的发展,软件研发模型逐步完善,软件交付质量越来越受到软件公司的重视,软件测试技术特别是自动化测试技术开始在软件系统研发过程中发挥着越来越重要的作用. 与传统的手工测试技术相比,自动化测试 ...

  2. 简明Vim练级攻略(转载)

    前言 今天看到这篇文章,共鸣点非常多.它把Vim使用分为4个级别,目前我自己是熟练运用前面三级的命令,在培养习惯使用第四级.完全就是我这一年来坚持使用Vim的过程.所以不管怎么我要转载这篇文章.翻译自 ...

  3. 简明Vim练级攻略(转)

    前言今天看到这篇文章,共鸣点非常多.它把Vim使用分为4个级别,目前我自己是熟练运用前面三级的命令,在培养习惯使用第四级.完全就是我这一年来坚持使用Vim的过程.所以不管怎么我要转载这篇文章.翻译自& ...

  4. Vim练级攻略(转)

    转自平凡的世界:http://www.ccvita.com/ 前言今天看到这篇文章,共鸣点非常多.它把Vim使用分为4个级别,目前我自己是熟练运用前面三级的命令,在培养习惯使用第四级.完全就是我这一年 ...

  5. (转)Vim练级攻略

    (转)Vim练级攻略 原文链接:http://coolshell.cn/articles/5426.html vim的学习曲线相当的大(参看各种文本编辑器的学习曲线),所以,如果你一开始看到的是一大堆 ...

  6. Java - 框架之 SpringBoot 攻略day01

          Spring-Boot 攻略 day01 spring-boot   一. 基本配置加运行   1. 导入配置文件(pom.xml 文件中)   <parent> <gr ...

  7. Python学习--21天Python基础学习之旅(Day01、Day02)

    21天的python基础学习,使用<Python从入门到实践>,并且需要手敲书中的code,以下为整个学习过程的记录. Day01: 安装python时要选择复选框 Add Python ...

  8. Groovy脚本基础全攻略

    1 背景 Groovy脚本基于Java且拓展了Java,所以从某种程度来说掌握Java是学习Groovy的前提,故本文适用于不熟悉Groovy却想快速得到Groovy核心基础干货的Java开发者(注意 ...

  9. javase基础复习攻略《十》

    按照计划本篇为大家总结JAVA的网络编程,什么叫网络编程呢?网络编程!=网站编程,对于这一点大家一定要注意,很多小朋友都曾经这么认为.既然谈到网络编程,咱们先了解一下网络的基础知识,什么是计算机网络? ...

随机推荐

  1. Findbug插件静态java代码扫描工具使用

    本文转自http://blog.csdn.net/gaofuqi/article/details/22679609 感谢作者 FindBugs 是由马里兰大学提供的一款开源 Java静态代码分析工具. ...

  2. 浅谈 System.Decimal 结构

    引言 我们知道,Microsoft .NET Framework 中的 System.Decimal 结构(在 C# 语言中等价于 decimal keyword)用来表示十进制数,范围从 -(296 ...

  3. 深入剖析Android四大组件(一)——Activity生命周期具体解释

    1.管理Activity的生命周期 不管是正在执行的Activity还是没有执行的Activity,它们都接受Android的框架管理,这使得Activity处于不同的生命周期. ①Activity的 ...

  4. Android studio第一次使用配置(三)gradle项目构建

    1.gradle的概念 2.gradle配置jar包.和libs目录导入jar包的差别 3.签名打包: (1)Studio (2)命令行 (3)gradle wrapper的原理 4.BuildCon ...

  5. 初触Python,关于pyquery解析html(百度贴吧)

    一直听同事说Python是个奇妙的语言,上周在逛知乎的时候深受这个话题的启示. 能利用爬虫技术做到哪些非常酷非常有趣非常实用的事情? 先是说到IDE的选择,作为python新人,尽管知道mac终端自带 ...

  6. ssdb底层实现——ssdb底层是leveldb,leveldb根本上是skiplist(例如为存储多个list items,必然有多个item key,而非暴力string cat),用它来做redis的list和set等,势必在数据结构和算法层面上有诸多不适

    我已经在用ssdb的hash结构,存储了很多数据了,但是我现在的用法正确吗? 我使用hash结构合理吗? 1. ssdb数据库说是类似redis,而且他们都有hash结构,但是他们的命名有点不同,ss ...

  7. codeforces 898F Hash

    F. Restoring the Expression time limit per test 2 seconds memory limit per test 256 megabytes input ...

  8. 【POJ 3740】 Easy Finding

    [题目链接] http://poj.org/problem?id=3740 [算法] Dancing Links算法解精确覆盖问题 详见这篇文章 : https://www.cnblogs.com/g ...

  9. 【POJ 1964】 City Game

    [题目链接] http://poj.org/problem?id=1964 [算法] 记f[i]表示第i行最多向上延伸的行数 然后,对于每一行,我们用单调栈计算出这一行向上延伸的最大矩形面积,取最大值 ...

  10. spring 监听器 IntrospectorCleanupListener简介

    转自:https://blog.csdn.net/ywb201314/article/details/51144256 其中JavaBeans Introspector是一个类,位置在Java.bea ...