python基础之数据类型与变量

  • 一.变量

    变量作用:保存状态(程序的运行本质是一系列状态的变化,变量的目的就是用来保存状态,变量值的变化就构成了程序运行的不同结果。)

Age=10 ----> Int(10)-------->__int__()

  变量命名规则遵循标识符命名规则

链式赋值(y=x=a=1)、多元赋值(x,y=1,2)、增量赋值(x+=1)

             python中的数据类型:

     python使用对象模型来存储数据,每一个数据类型都有一个内置的类,每新建一个数据,实际就是在初始化生成一个对象,即所有数据都是对象
对象三个特性

          身份:内存地址,可以用id()获取

          类型:决定了该对象可以保存什么类型值,可执行何种操作,需遵循什么规则,可用type()获取

          值:对象保存的真实数据

  • 2.2 标准数据类型:
  • 2.2.1 数字

    定义:a=1

    特性:

    1.只能存放一个值

    2.一经定义,不可更改

    3.直接访问

    分类:整型,长整型,布尔,浮点,复数

  • >>> 10 10 --------->默认十进制

  • >>> oct(10) '012' --------->八进制表示整数时,数值前面要加上一个前缀“0”

  • >>> hex(10) '0xa' --------->十六进制表示整数时,数字前面要加上前缀0X或0x

整型工厂函数int()

class int(object):

  """

  int(x=0) -> int or long

  int(x, base=10) -> int or long

def __abs__(self): """ 返回绝对值 """

def __cmp__(self, y): """ 比较两个数大小 """

def __coerce__(self, y): """ 强制生成一个元组 """

def __float__(self): """ 转换为浮点类型 """

def __hex__(self): """ 返回当前数的 十六进制 表示 """

def __oct__(self): """ 返回改值的 八进制 表示 """

def __int__(self): """ 转换为整数 """

def __ceil__(self, *args, **kwargs): # real signature unknown """ 整数返回自己 如果是小数 math.ceil(3.1)返回4

.....Etc

  • 2.2.1.2 长整型long:

    注意,自从Python2起,如果发生溢出,Python会自动将整型数据转换为长整型,
    所以如今在长整型数据后面不加字母L也不会导致严重后果了。
    python3.*
    长整型,整型统一归为整型

  • 2.2.1.3 布尔bool:
    True 和False
    1和0
  • 2.2.1.4 浮点数float:
    Python的浮点数就是数学中的小数,在运算中,整数与浮点数运算的结果是浮点数。
  • 2.2.1.5 复数complex:
    复数由实数部分和虚数部分组成,一般形式为x+yj,其中的x是复数的实数部分,y是复数的虚数部分,这里的x和y都是实数。
  • 2.2.1.6 数字相关内建函数

  • 2.2.2 字符串
    定义:它是一个有序的字符的集合,用于存储和表示基本的文本信息,‘’或“”或‘’‘  ’‘’中间包含的内容称之为字符串
    特性:
    1.只能存放一个值
    2.不可变
    3.按照从左到右的顺序定义字符集合,下标从0开始顺序访问,有序
    补充:
      1.字符串的单引号和双引号都无法取消特殊字符的含义,如果想让引号内所有字符均取消特殊意义,在引号前面加r,如name=r'l\thf'
      2.unicode字符串与r连用必需在r前面,如name=ur'l\thf'
  • 2.2.2.1 字符串创建

    ‘hello world’

  • 2.2.2.2 字符串常用操作

    移除空白
       分割
       长度
       索引
       切片

  • 2.2.2.3 字符工厂函数str()
    class str(object):
        """
        str(object='') -> str
        str(bytes_or_buffer[, encoding[, errors]]) -> str

def capitalize(self): # real signature unknown; restored from __doc__ """ 首字母变大写 S.capitalize() -> str

def center(self, width, fillchar=None): # real signature unknown; restored from __doc__ """ 原来字符居中,不够用空格补全 S.center(width[, fillchar]) -> str

      def count(self, sub, start=None, end=None): # real signature unknown; restored from __doc__ """ 从一个范围内的统计某str出现次数 S.count(sub[, start[, end]]) -> int

      def expandtabs(self, tabsize=8): # real signature unknown; restored from __doc__ """ 将字符串中包含的\t转换成tabsize个空格 S.expandtabs(tabsize=8) -> str

      def find(self, sub, start=None, end=None): # real signature unknown; restored from __doc__ """ S.find(sub[, start[, end]]) -> int

def format(self, *args, **kwargs): # known special case of str.format

""" 格式化输出 三种形式:

形式一. >>> print('{0}{1}{0}'.format('a','b'))

aba

      形式二:(必须一一对应)

>>> print('{}{}{}'.format('a','b'))

Traceback (most recent call last): File "<input>", line 1, in <module> IndexError: tuple index out of range

>>>print('{}{}'.format('a','b'))

ab

       形式三:

       >>> print('{name} {age}'.format(age=12,name='lhf'))

       lhf 12

def isdigit(self): # real signature unknown; restored from __doc__ """ S.isdigit() -> bool

         def join(self, iterable): # real signature unknown; restored from __doc__ """

        #对序列进行操作(分别使用' '与':'作为分隔符)

        >>> seq1 = ['hello','good','boy','doiido']

      >>> print ' '.join(seq1)

      hello good boy doiido

      >>> print ':'.join(seq1)

      hello:good:boy:doiido

       #合并目录

      >>> import os

      >>> os.path.join('/hello/','good/boy/','doiido')

       '/hello/good/boy/doiido'

          def split(self, sep=None, maxsplit=-1): # real signature unknown; restored from __doc__ 
      """ 以sep为分割,将S切分成列表,与partition的区别在于切分结果不包含sep, 如果一个字符串中包含多个sep那么maxsplit为最多切分成几部分
      >>> a='a,b c\nd\te'
      >>> a.split()
      ['a,b', 'c', 'd', 'e']

      def splitlines(self, keepends=None): # real signature unknown; restored from __doc__
      """ Python splitlines() 按照行('\r', '\r\n', \n')分隔, 返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如 果为 True,则保留换行符。
      >>> x
      'adsfasdf\nsadf\nasdf\nadf'
      >>> x.splitlines()
      ['adsfasdf', 'sadf', 'asdf', 'adf']
      >>> x.splitlines(True)
      ['adsfasdf\n', 'sadf\n', 'asdf\n', 'adf']
      ...Etc

    定义:[]内以逗号分隔,按照索引,存放各种数据类型,每个位置代表一个元素
    特性:
    1.可存放多个值
    2.可修改指定索引位置对应的值,可变
    3.按照从左到右的顺序定义列表元素,下标从0开始顺序访问,有序 

    list_test=[’lhf‘,12,'ok']
    或
    list_test=list('abc')
    或
    list_test=list([’lhf‘,12,'ok'])

    索引
    切片
    追加
    删除
    长度
    切片
    循环
    包含  

    class list(object): """ list() -> new empty list

    def append(self, p_object)

    def clear(self)

    def copy(self):两份内存

    def count(self, value)

    def insert(self, index, p_object)

    def pop(self, index=None):删除并返回    pop[]:默认删除最后一个

    def remove(self, value)

    def reverse(self)

    def sort(self, key=None, reverse=False)

   def index(self, value, start=None, stop=None)
   def extend(self, iterable):两个列表的合并拼接 
   ...Etc

   1、算数运算 2、比较运算 3、赋值运算 4、位运算

   5、逻辑运算(与或非) 6、成员运算 (in not in)7.身份运算(is is not)8.运算符优先级自上而下,优先级从高到低

and注解

  1. 在Python 中,and 和 or 执行布尔逻辑演算,如你所期待的一样,但是它们并不返回布尔值;而是,返回它们实际进行比较的值之一。
  2. 在布尔上下文中从左到右演算表达式的值,如果布尔上下文中的所有值都为真,那么 and 返回最后一个值。
  3. 如果布尔上下文中的某个值为假,则 and 返回第一个假值

  or注解

  1. 使用 or 时,在布尔上下文中从左到右演算值,就像 and 一样。如果有一个值为真,or 立刻返回该值
  2. 如果所有的值都为假,or 返回最后一个假值
  3. 注意 or 在布尔上下文中会一直进行表达式演算直到找到第一个真值,然后就会忽略剩余的比较值

  and-or结合使用

  1. 结合了前面的两种语法,推理即可。
  2. 为加强程序可读性,最好与括号连用,例如:
    (1 and 'x') or 'y'

Python_Day2_基础2的更多相关文章

  1. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  2. node-webkit 环境搭建与基础demo

    首先去github上面下载(地址),具体更具自己的系统,我的是windows,这里只给出windows的做法 下载windows x64版本 下载之后解压,得到以下东西 为了方便,我们直接在这个目录中 ...

  3. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  4. Golang, 以17个简短代码片段,切底弄懂 channel 基础

    (原创出处为本博客:http://www.cnblogs.com/linguanh/) 前序: 因为打算自己搞个基于Golang的IM服务器,所以复习了下之前一直没怎么使用的协程.管道等高并发编程知识 ...

  5. [C#] C# 基础回顾 - 匿名方法

    C# 基础回顾 - 匿名方法 目录 简介 匿名方法的参数使用范围 委托示例 简介 在 C# 2.0 之前的版本中,我们创建委托的唯一形式 -- 命名方法. 而 C# 2.0 -- 引进了匿名方法,在 ...

  6. HTTPS 互联网世界的安全基础

    近一年公司在努力推进全站的 HTTPS 化,作为负责应用系统的我们,在配合这个趋势的过程中,顺便也就想去搞清楚 HTTP 后面的这个 S 到底是个什么含义?有什么作用?带来了哪些影响?毕竟以前也就只是 ...

  7. Swift与C#的基础语法比较

    背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...

  8. .NetCore MVC中的路由(1)路由配置基础

    .NetCore MVC中的路由(1)路由配置基础 0x00 路由在MVC中起到的作用 前段时间一直忙于别的事情,终于搞定了继续学习.NetCore.这次学习的主题是MVC中的路由.路由是所有MVC框 ...

  9. .NET基础拾遗(5)多线程开发基础

    Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...

随机推荐

  1. Altium Designer 文档信息设置以及模板制作

    原理图文档模板制作方法一.在DXP原理图设计环境下,新建一个自由原理图文档.单击:文件→新建→原理图,或者使用快捷键Ctrl+N打开Files资源面板,在“新建”项目下的选择“Schematic Sh ...

  2. ps aux和ps -ef命令区别

      ps aux 是用BSD的格式来显示 java这个进程 显示的项目有:USER,PID,%CPU,%MEM,VSZ,RSS,TTY,STAT,START,TIME,COMMAND   ps -ef ...

  3. thttpd和cgilua安装与运行流程分析

    安装 参考如下博文安装thttpd软件 http://blog.csdn.net/21aspnet/article/details/7045845 http://blog.csdn.net/drago ...

  4. Hadoop学习(5)-- Hadoop2

    在Hadoop1(版本<=0.22)中,由于NameNode和JobTracker存在单点中,这制约了hadoop的发展,当集群规模超过2000台时,NameNode和JobTracker已经不 ...

  5. # java对xml文件的基本操作

    下面是简单的总结三种常用的java对xml文件的操作 1. dom方式对xml进行操作,这种操作原理是将整个xml文档读入内存总,在内存中进行操作,当xml文档非常庞大的时候就会出现内存溢出的异常,这 ...

  6. 十分钟学会python

    1.raw_input的使用 从键盘读取信息,返回字符串. 例: hrs = raw_input("Enter Hours:")pay=raw_input("Enter ...

  7. c语言数据结构和算法库--cstl---王博--相关网站和博客

    1.官网 http://libcstl.org/download.html 2.下载地址 http://www.pudn.com/downloads171/sourcecode/os/detail79 ...

  8. javascript设计模式简介

  9. Mysql 设置utf-8 真正一劳永逸的方法

    用 bash 进入linux 之后,再 mysql -u root -p ,如果insert into 某个表,总是会出现乱码. 网上搜了一堆,其中一个老外的说法才适用.用 set names utf ...

  10. JQuery MultiSelect(左右选择框)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...