显式转换

int(x [,base]) ⇒ 将x转换为一个十进制的整数

long(x [,base]) ⇒ 将x转换为一个十进制的长整数

float(x) ⇒ 将x转换为一个浮点数

str(object) ⇒ 转换为字符串

repr(object) ⇒ 转换为表达式字符串

eval(str) ⇒ 用来计算在字符串中的有效Python表达式,并返回一个对象

tuple(seq) ⇒ 将序列seq转换为一个元组

list(seq) ⇒ 将序列seq转换为一个列表

chr(x ) ⇒ 将一个整数转换为一个字符

unichr(x ) ⇒ 将一个整数转换为Unicode字符

ord(x ) ⇒ 将一个字符转换为它的整数值

hex(x ) ⇒ 将一个整数转换为一个十六进制字符串

oct(x ) ⇒ 将一个整数转换为一个八进制字符串

Non-String转换成String类型

1.List -> String

>>> li = ['My','name','is','Jmilk']
>>> strLi = str(li)
>>> print(strLi)
['My', 'name', 'is', 'Jmilk']
>>> type(strLi)
<class 'str'>

2.Tuple -> String

>>> tup = ('my','name','is','jmilk')
>>> Tup = str(tup)
>>> Tup
"('my', 'name', 'is', 'jmilk')"
>>> type(Tup)
<class 'str'>

3.Dictionary -> String

>>> dic = {'name':'Jmilk','age':23}
>>> Dic = str(dic)
>>> Dic
"{'name': 'Jmilk', 'age': 23}"
>>> type(Dic)
<class 'str'>

str()和repr()的区别

(1)repr()支持eval(repr(object)) == object。

(2)str()函数的结果适合用户阅读,repr()的结果适合python解析器阅读,其中有一些Python解析器能够识别的数据细节,但这些细节一般对用户是多余的。

(3)repr()转换后的String对象可以通过求值运算eval()来还原到转换之前的对象,str()通常不需要eval()去处理。

>>> name = ('alex\n,reic\n,jane\n')
>>> print(str(name))
alex
,reic
,jane >>> print(repr(name))
'alex\n,reic\n,jane\n'

eval():

(1)能结合repr()函数将一个经过转换为Strng类型后的对象还原为转换之前的对象类型。

(2)eval()也被称为求值运算,可以将字符串str当成有效的表达式来求值并返回计算结果。

>>> name = ('My name is Jmilk\n')
>>> name1 = str(name)
>>> name1
'My name is Jmilk\n'
>>> name2 = repr(name)
>>> name2
"'My name is Jmilk\\n'"
>>> eval(name1)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "<string>", line 1
My name is Jmilk
^
SyntaxError: invalid syntax
>>> eval(name2)
'My name is Jmilk\n'

eval(str(Object))可能会报错,无法还原为原来的对象型。而eval(repr(object))却可以还原,下面例子:

>>> name = ('My','name','is','Jmilk\n')

>>> repr(name)
"('My', 'name', 'is', 'Jmilk\\n')" >>> eval(repr(name))
('My', 'name', 'is', 'Jmilk\n') >>> type(eval(repr(name)))
<class 'tuple'>

总结:str()函数主要是为了让人能够更好的阅读其内容,而rper()除了转换为String类型外,还能够被Python解析器识别其数据细节,从而repr()转换后的字符串能够被当作有效表达式来处理。
       注意:eval()函数最主要的功能是能够将字符串中有效的表达式进行计算并返回一个对象。如下:

>>> sum = '100 + 10'
>>> eval(sum)
110

Non-int转换成int类型 

int(x[, base=10]) -> int or long                         base:指定进制;  x:通常为一个String  ;base指定了x的进制。

1.float -> int  向下取整

>>> int(10.9)
10

2.string ->int  int('a',b) a为要转换的数字,b为a的进制,b必须标明,不然会出错。

>>> int('0xa',16)
10
>>> int('',2)
10
>>> int('0xa')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: '0xa'

 Non-float转换成float

float(x) -> floating point number
       Convert a string or number to a floating point number, if possible.
       可以接收Int和String类型参数,float()函数在连接数据库操作会被经常使用。当参数为String时,只能出现数字和一个点额任意组合,若出现多个点号,则会出现异常。

>>> float(10)
10.0 >>> float('')
100.0 >>> float('.98')
0.98 >>> float('.123.')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: could not convert string to float: '.123.'

Non-list转换成list

list(iterable) -> new list initialized from iterable’s items 
       使用迭代器中的元素生成一个新的列表

1.string -> list

Python全栈之路----类型转换的更多相关文章

  1. Python全栈之路----目录

    Module1 Python基本语法 Python全栈之路----编程基本情况介绍 Python全栈之路----常用数据类型--集合 Module2 数据类型.字符编码.文件操作 Python全栈之路 ...

  2. Python全栈之路目录结构

    基础 1.Python全栈之路-----基础篇 2.Python全栈之路---运算符与基本的数据结构 3.Python全栈之路3--set集合--三元运算--深浅拷贝--初识函数 4.Python全栈 ...

  3. Python全栈之路----常用模块----hashlib加密模块

    加密算法介绍 HASH       Python全栈之路----hash函数 Hash,一般翻译做“散列”,也有直接音译为”哈希”的,就是把任意长度的输入(又叫做预映射,pre-image),通过散列 ...

  4. python 全栈之路

    目录 Python 全栈之路 一. Python 1. Python基础知识部分 2. Python -函数 3. Python - 模块 4. Python - 面对对象 5. Python - 文 ...

  5. Python全栈之路----函数----返回值

    函数外部的代码想要获取函数的执行结果,就可以在函数里用return语句,把结果返回. def stu_register(name,age,course='PY',country='CN'): prin ...

  6. Python全栈之路----常用模块----软件开发目录规范

    目录基本内容 log  #日志目录 conf  #配置目录 core/luffycity  #程序核心代码目录  #luffycity 是项目名,建议用小写 libs/modules  #内置模块 d ...

  7. Python全栈之路----常用模块----shutil模块

    高级的 文件.文件包.压缩包 处理模块   参考Python之路[第四篇]:模块     #src是原文件名,fdst是新文件名 shutil.copyfileobj(fsrc, fdst[, len ...

  8. Python全栈之路----Python2与Python3

    金角大王Alex  python 之路,致那些年,我们依然没搞明白的编码 python2与python3的区别 py2 str = bytes 为什么有bytes? 是因为要表示图片.视频等二进制格式 ...

  9. Python全栈之路----函数进阶----装饰器

    Python之路,Day4 - Python基础4 (new版) 装饰器 user_status = False #用户登录后改为True def login(func): #传入想调用的函数名 de ...

随机推荐

  1. VS2015 scanf 函数报错 error C4996: 'scanf'

    错误提示:error C4996: 'scanf': This function or variable may be unsafe. Consider using scanf_s instead. ...

  2. Bulbs【暴力?】

    问题 B: Bulbs 时间限制: 1 Sec  内存限制: 128 MB 提交: 216  解决: 118 [提交] [状态] [命题人:admin] 题目描述 Greg has an m × n ...

  3. 20175312 2018-2019-2 《Java程序设计》第2周学习总结

    20175312 2018-2019-2 <Java程序设计>第2周学习总结 教材学习内容总结 已依照蓝墨云班课的要求完成了第二.三章的学习,主要的学习渠道是视频,和书的课后习题. 总结如 ...

  4. SAP的软件维护费用,交还是不交?

    SAP的软件维护费用,交还是不交? 首先我们要明确一点,什么是软件维护费用?     软件维护费用是指在企业购买了软件厂商的软件产品之后,软件厂商每年按照一定比例向企业收取一定的技术支持维护费用.收取 ...

  5. C#设置IE代理

    public class IEProxySetting { public static bool UnsetProxy() { return SetProxy(null, null); } publi ...

  6. HADOOP HA 踩坑 - 所有 namenode 都是standby

    报错: 无明显报错 状况: 所有namenode都是standby,即ZK服务未生效 尝试一:手动强制转化某个namenode为active 操作:在某台namenode上,执行 hdfs haadm ...

  7. Go语言学习之10 Web开发与Mysql数据库

    本节主要内容: 1. http编程2. mysql使用 1. http编程 (1)http编程分析 Go原生支持http,import(“net/http”) Go的http服务性能和nginx比较接 ...

  8. 【转】 C++析构函数的作用和用法

    转自:https://www.cnblogs.com/puyangsky/p/5319470.html 一.定义1. 作用:对象消亡时,自动被调用,用来释放对象占用的空间2.特点:   (1) 名字与 ...

  9. Lab 9-2

    Analyze the malware found in the file Lab09-02.exe using OllyDbg to answer the following questions. ...

  10. 『流畅的Python』第5章笔记_一等函数