大数据处理之道(十分钟学会Python)
一:python 简介
(1)Python的由来
Python(英语发音:/ˈpaɪθən/), 是一种面向对象、解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991
年。Python语法简洁而清晰,具有丰富和强大的类库。它常被昵称为胶水语言,它能够把用其他语言制作的各种模块(尤其是C/C++)很轻松地联结
在一起。常见的一种应用情形是,使用Python快速生成程序的原型(有时甚至是程序的最终界面),然后对其中有特别要求的部分,用更合适的语言改写,
比如3D游戏中的图形渲染模块,性能要求特别高,就可以用C++重写。
(2)Python 语法简介 ---- 类型转化
int(x [,base ]) 将x转换为一个整数
long(x [,base ]) 将x转换为一个长整数
float(x ) 将x转换到一个浮点数
complex(real [,imag ]) 创建一个复数
str(x ) 将对象 x 转换为字符串
repr(x ) 将对象 x 转换为表达式字符串
eval(str ) 用来计算在字符串中的有效Python表达式,并返回一个对象
tuple(s ) 将序列 s 转换为一个元组
list(s ) 将序列 s 转换为一个列表
chr(x ) 将一个整数转换为一个字符
unichr(x ) 将一个整数转换为Unicode字符
ord(x ) 将一个字符转换为它的整数值
hex(x ) 将一个整数转换为一个十六进制字符串
oct(x ) 将一个整数转换为一个八进制字符串
(3)Python 语法简介 ---- 类型转化
s + r 序列连接
s * n , n * s s的 n 次拷贝,n为整数
s % d 字符串格式化(仅字符串)
s[i] 索引
s[i :j ] 切片
x in s , x not in s 从属关系
for x in s : 迭代
len(s) 长度
min(s) 最小元素
max(s) 最大元素
s[i ] = x 为s[i]重新赋值
s[i :j ] = r 将列表片段重新赋值
del s[i ] 删除列表中一个元素
del s[i :j ] 删除列表中一个片段
(4)(3)Python 语法简介 ---- 类型转化
x >> y 右移
x & y 按位与
x | y 按位或
x ^ y 按位异或 (exclusive or)
~x 按位翻转
x + y 加
x - y 减
x * y 乘
x / y 常规除
x // y 地板除
x ** y 乘方 (xy )
x % y 取模 (x mod y )
-x 改变操作数的符号位
+x 什么也不做
~x ~x=-(x+1)
abs(x ) 绝对值
divmod(x ,y ) 返回 (int(x / y ), x % y )
pow(x ,y [,modulo ]) 返回 (x ** y ) x % modulo
round(x ,[n]) 四舍五入,n为小数点位数
x < y 小于
x > y 大于
x == y 等于
x != y 不等于(与<>相同)
x >= y 大于等于
x <= y 小于等于
二:python应用
(1) 文件处理

- filename = raw_input('Enter your file name') #输入要遍历读取的文件路径及文件名
- file = open(filename,'r')
- done = 0
- while not done:
- aLine = file.readline()
- if(aLine != ''):
- print aLine,
- else:
- done = 1
- file.close() #关闭文件
解释:
.readline() 和 .readlines() 之间的差异是后者一次读取整个文件,.readlines() 自动将文件内容分析成一个行的列表,该列表可以由 Python 的 for ... in ... 结构
进行处理。另一方面,.readline() 每次只读取一行,通常比 .readlines() 慢得多。仅当没有足够内存可以一次读取整个文件时,才应该使用 .readline()。
如果Python文件读到了文件尾,则会返回一个空字符串‘’,而如果是读到一个空行的话,则会返回一个‘\n’
Python的readline()方法,每行最后都会加上一个换行字符‘\n’。有时候有的文件最后一行没有以'\n'结尾时,不返回‘\n’。
readlines()方法返回的是一个列表,而readline()返回一个字符串。
(2)错误处理
Python报错TypeError: 'str' object is not callable
当一般内部函数被用作变量名后可能出现此错误。比如:
range=1
for i in range(0,1):
………
就会报这样的错误
这样的错会报在for行,但是时间引起的原因却是在range=1这行,如果两行相距较远,怎很难被发现。所以要特别注意不要用内部已有的变量和函数名作自定义变量名。或者str被预先定义了
str=10
for i in range(1,10):
print str(i)
(3) 综合应用,文件读取,控制台读取,时间转化,编码转换

- import time
- from time import strftime
- import sys
- reload(sys)
- sys.setdefaultencoding('utf8')
- # -*- coding: cp936 -*-
- print ("Hello, Python!")
- #!/usr/bin/python
- a = 21
- b = 10
- c = 0
- c = a + b
- print "Line 1 - Value of c is ", c
- c = a - b
- print "Line 2 - Value of c is ", c
- c = a * b
- print "Line 3 - Value of c is ", c
- c = a / b
- print "Line 4 - Value of c is ", c
- c = a % b
- print "Line 5 - Value of c is ", c
- a = 2
- b = 3
- c = a**b
- print "Line 6 - Value of c is ", c
- a = 10
- b = 5
- c = a//b
- print "Line 7 - Value of c is ", c
- # for repeat its
- list = [2, 4, 6, 8]
- sum = 0
- for num in list:
- sum = sum + num
- print("The sum is:", sum)
- # print and Input, assignment
- print("Hello, I'm Python!")
- name = input('What is your name?\n')
- print('Hi, %s.' % name)
- # test for
- fruits = ['Banana', 'Apple', 'Lime']
- loud_fruits = [fruit.upper() for fruit in fruits]
- print(loud_fruits)
- # open, write and read file
- fo = open("./tmp/foo.txt","w+")
- fo.write("Python is a gerat language.\nYeah its great!!\nI am zhang yapeng, who are you?\n")
- t_str = u'我是张燕鹏,您是什么货色?'
- print(t_str)
- fo.write(t_str)
- fo.close()
- #read and write
- fr = open("./tmp/foo1.txt","r+")
- fw = open("foo_rw.txt","wb")
- done = 0;
- localtime = time.asctime(time.localtime(time.time()))
- print "Local current time : ", localtime
- fw.write(localtime + "\n")
- while not done:
- t_str = fr.readline()
- if(t_str != ''):
- print "Read String is : ", t_str
- fw.write(t_str)
- else:
- done = 1
- fr.close()
- fw.close()
- # test time (import)
- localtime = time.localtime(time.time())
- print "Local current time : ", localtime
- # format the time from time import strftime
- t_time = strftime( '%Y-%m-%d %H:%M:%S', localtime)
- print "formatting local current time : ", t_time
- # design the time by yourself
- year = str(localtime.tm_year)
- mon = str(localtime.tm_mon)
- day = str(localtime.tm_mday)
- hour = str(localtime.tm_hour)
- mins = str(localtime.tm_min)
- sec = str(localtime.tm_sec)
- newtime = u"时间是: " + year + "年" + mon + "月" + day + "日 " + hour + ":" + mins + ":" + sec
- print "Local current time : ", newtime
(4)运行图:
(5) 总结:
(1)Python是一门入手非常快的语言,处理大数据的好语言,一些规范非常类似于c++语言,例如语法和一些函数命名,文件的打开和读写,以及
读写方式,非常类似于c++
(2)正如,开头所写的 “python是胶水语言,使用Python快速生成程序的原型(有时甚至是程序的最终界面),然后对其中有特别要求的部分,用更合适
的语言改写,比如3D游戏中的图形渲染模块,性能要求特别高,就可以用C++重写。”
(3)分享一下非常基础的系统的学习网站
(4)W3CSchool.cc (3)中提到的学习网站是非常基础的人们课程,要是想深入,具体的内容可以百度。
原文链接:http://blog.csdn.net/u010700335/article/details/42025391
大数据处理之道(十分钟学会Python)的更多相关文章
- 快速入门:十分钟学会Python
初试牛刀 假设你希望学习Python这门语言,却苦于找不到一个简短而全面的入门教程.那么本教程将花费十分钟的时间带你走入Python的大门.本文的内容介于教程(Toturial)和速查手册(Cheat ...
- 快速入门:十分钟学会Python(转)
初试牛刀 假设你希望学习Python这门语言,却苦于找不到一个简短而全面的入门教程.那么本教程将花费十分钟的时间带你走入Python的大门.本文的内容介于教程(Toturial)和速查手册(Cheat ...
- 高速入门:十分钟学会Python
初试牛刀 如果你希望学习Python这门语言.却苦于找不到一个简短而全面的新手教程.那么本教程将花费十分钟的时间带你走入Python的大门.本文的内容介于教程(Toturial)和速查手冊(Cheat ...
- 十分钟学会python
1.raw_input的使用 从键盘读取信息,返回字符串. 例: hrs = raw_input("Enter Hours:")pay=raw_input("Enter ...
- PHP学习过程_Symfony_(3)_整理_十分钟学会Symfony
这篇文章主要介绍了Symfony学习十分钟入门教程,详细介绍了Symfony的安装配置,项目初始化,建立Bundle,设计实体,添加约束,增删改查等基本操作技巧,需要的朋友可以参考下 (此文章已被多人 ...
- Python十分钟学会
初试牛刀 假设你希望学习Python这门语言,却苦于找不到一个简短而全面的入门教程.那么本教程将花费十分钟的时间带你走入Python的大门.本文的内容介于教程(Toturial)和速查手册(Cheat ...
- 十分钟学会 tmux
tmux 是一款终端复用命令行工具,一般用于 Terminal 的窗口管理.在 macOS 下,使用 iTerm2 能应付绝大多数窗口管理的需求. 如上图所示,iTerm2 能新建多个标签页(快捷键 ...
- 快速入门:十分钟学会PythonTutorial - Learn Python in 10 minutes
This tutorial is available as a short ebook. The e-book features extra content from follow-up posts ...
- python第八篇:十分钟学会Flask
什么是Flask Flask是一个基于Python并且依赖于Jinja2模板引擎和Werkzeug WSGI服务的一个微型框架 Flask中包含一个轻量级的web 服务器主要用于在开发阶段测试使用 F ...
随机推荐
- Tensorflow 初级教程(一)
初步介绍 Google 于2011年推出人工深度学习系统——DistBelief.通过DistBelief,Google能够扫描数据中心数以千计的核心,并建立更大的神经网络.Google 的这个系统将 ...
- SAP 物料 移动类型
[转自 http://blog.sina.com.cn/s/blog_494f9a6b0102edf7.html] SAP 物料 移动类型 (2013-12-03 10:15:01) 转载▼ 分类 ...
- SAP basis 常用事物
1.创建一个新的用户 完成client创建和拷贝后,在开始正式工作之前,需要创建新的用户. 用这个用户进行工作.默认ddic和sap*用户不要用于实际的业务. 创建用户的过程很简单,只要以su01 ...
- Iptalbes练习题(三)
场景需求: (1)员工在公司内部(192.168.124.0/24 ,192.168.122.0/24 )能访问服务器上任何服务 (2)当员工出差,通过VPN连接到公司 (3)公司门户网站允许公网访问 ...
- vim中使用sed去除网上copy的源代码行号和空格
有些时候,在网上搜索到的代码都包含有行号,高亮显示控件不支持直接提取,如: test.sh 01 #!/bin/bash 02 echo “aaa” 简单的去掉行号和前面的空格: 方案一: 1.vim ...
- 《程序员代码面试指南》第三章 二叉树问题 二叉树按层打印和ZigZag打印
题目 二叉树按层打印和ZigZag打印 java代码 package com.lizhouwei.chapter3; import java.util.LinkedList; import java. ...
- javascript数字时钟
<html> <head> <script type="text/javascript"> function startTime() { var ...
- [算法]找到无序数组中最小的K个数
题目: 给定一个无序的整型数组arr,找到其中最小的k个数. 方法一: 将数组排序,排序后的数组的前k个数就是最小的k个数. 时间复杂度:O(nlogn) 方法二: 时间复杂度:O(nlogk) 维护 ...
- 希尔排序(Shell Sort)
一.思路 希尔排序是基于插入排序算法,通过允许不相邻的元素进行交换这一简单的改进,使数组变为局部有序,最终再用插入排序. 希尔排序的思想是使数组中任意间隔h的元素都是有序的.这样的数组被称为h有序数组 ...
- Mac安装使用kettle
kettle是一个ETL工具 下载安装 https://jaist.dl.sourceforge.net/project/pentaho/Data Integration/ 选择版本后下载,并解压,如 ...