孙广东  2016.1.1

交互:

C# 运行Python代码:

http://stackoverflow.com/questions/11779143/run-a-python-script-from-c-sharp

反着来:

http://stackoverflow.com/questions/3260015/run-a-c-sharp-application-from-python-script

Python语言的特点:
高级语言
内置电池(大量的标准库)
解释型(有时JIT编译)
面向对象(尤其是Python 3)
强类型动态语义
语法强调可读性
支持重用通过模块和包

Python程序的“形状” :
    Python定义代码块(在Python中使用 空格 和 冒号)。

看一个 Demo:

import random

def get_days():
# List<string> days = new List<sting>();
# days[]
days = ['mon','tues','wed','thurs','fri','sat','sun']
return days def get_random_report():
weather = ['sunny', 'lovely','cold']
return weather[ random.randint(0, len(weather) - 1)] def main():
days = get_days() for day in days:
report = get_random_report()
print("On {0} it will be {1}.".format(day, report)) if __name__ == "__main__":
main()

C# 都有什么呢?

一、 Everything is an object (一切皆对象)

C# :

class Document: object
{
public void Serialize()
{
// ...
} public override string ToString()
{
return "I am a document ";
}
}

Python:

class Document(object):
def serialize(self):
print("太好了!") def __str__(self):
return "I am a document."

二、IEnumerable + foreach loops

C# :

        int[] numbers = new[] {1, 2, 3, 4, 5, 6};
foreach (var n in numbers)
{
Console.Write(n + ",");
}
class ShoppingCart : IEnumerable<Tuple<string, float>>
{
List<Tuple<string, float>> cartItems = new List<Tuple<string, float>>(); public void Add(string name, float price)
{
cartItems.Add(new Tuple<string, float>(name, price));
} public IEnumerator<Tuple<string, float>> GetEnumerator()
{
return cartItems.GetEnumerator();
} IEnumerator IEnumerable.GetEnumerator()
{
return cartItems.GetEnumerator();
}
}

Python :

numbers = [1, 2, 3, 4, 5, 6]

for n in numbers:
print(n, end=',')
for v in enumerate(numbers):
print(v, end=',')
for index, k in enumerate(numbers):
print(k, end=',')
class CarItem:
def __init__(self, name, price):
self.price = price
self.name = name def __repr__(self):
return "({0}, ${1})".format(self.name, self.price) class ShoppingCart:
def __init__(self):
self.__items = [] def add(self, cart_item):
self.__items.append(cart_item) def __iter__(self):
return self.__items.__iter__() print()
print() cart = ShoppingCart()
cart.add(CarItem("CD", 19.99))
cart.add(CarItem("Record", 17.99)) for item in cart.items:
print(item)

三、Properties (int Age {get; set;})

C# :

    class ShoppingCart
{
List<Tuple<string, float>> cartItems = new List<Tuple<string, float>>(); public float TotalPrice
{
get
{
float total = 0;
foreach (var item in cartItems)
{
total += item.Item2;
}
return total;
}
}
}

Python :

class ShoppingCart:
@property
def total_price(self):
total = 0.0
for item in self.__items:
total += item.price
return total

print("Total price is ${0:,}".format(cart.total_price))

四、Anonymous types (匿名类型)

C#:

    public static void Main(String[] args)
{
var o = new
{
Id = 2,
Registered = true
}; Console.WriteLine(o); if (o.Registered)
{
Console.WriteLine("They are registered...");
}
}

python:

class AnonObject(dict):
__getattr__ = dict.get
__setattr__ = dict.__setitem__ person = {
"name": "Michael",
"age": 40
}
anonPerson = AnonObject(name = "Michael", age=40) print(anonPerson)
print(anonPerson["name"])
print(anonPerson.name)
print(anonPerson.age)

五、Lambda expressions

C#:

    private static IEnumerable<int> FindNumbers(Predicate<int> predicate)
{
for (int i = 0; i < 100; i++)
{
if (predicate(i))
{
yield return i;
}
}
} private IEnumerable<int> nums = FindNumbers(n => n%11 == 0);
// [0, 11,22,33,44,55,66,77,88,99]

python:

def get_numbers(limit, predicate):
for n in range(0, limit):
if predicate(n):
yield n def divide_by_ll(n):
return n % 11 == 0 output = list(get_numbers(40, divide_by_ll))
print(output)

def get_numbers(limit, predicate):
for n in range(0, limit):
if predicate(n):
yield n # def divide_by_ll(n):
# return n % 11 == 0 output = list(get_numbers(40,lambda n : n % 11 ==0 ))
print(output)

六、NuGET package management

七、Entity Framework 》ORMs

八、ASP.NET MVC

九、LINQ

C# :

        var older =
from p in people
where p.age > 30
orderby p.age descending
select new { age = p.age, name = p.name }

python:

class Person:
def __init__(self, name, age, hobby):
self.hobby = hobby
self.name = name
self.age = age def __repr__(self):
return "{0} is {1} and likes {2}".format(self.name, self.age, self.hobby) class AnonObject(dict):
__getattr__ = dict.get
__setattr__ = dict.__setitem__ people = [
Person("Jeff", 50, "Biking"),
Person("Michael", 40, "Biking"),
Person("Saerh", 30, "Running"),
Person("Tony", 24, "Jogging"),
Person("Zoe", 12, "TV"),
] bikers = [
AnonObject(Name = p.name, PastTime = p.hobby)
for p in people
if p.hobby == "Biking"
]
bikers.sort(key=lambda p:p.Name) for b in bikers:
print(b)

十、Iterator methods / yield return

C#:

    private static IEnumerable<int> FibonacciGenerator()
{
int current = 1;
int next = 1; yield return current;
while (true)
{
int temp = current + next;
current = next;
next = temp;
yield return current;
}
}

python:

def fibinnoci():
current = 0
nxt = 1 while True:
current, nxt = nxt, current + nxt
#print("Generating" + str(current))
yield current for n in fibinnoci():
if n > 200:
break print(n, end=', ')
# 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144,

十一、JIT compilation








C#程序猿学习 Python的更多相关文章

  1. 人在囧途——Java程序猿学习Python

    引言 LZ之前其实一直对python都很好奇,只是苦于平时没有时间去了解它,因此趁着51假期这个机会,便迫不及待的开始了自己的探索.作为一个标准的Java程序猿,在了解python的过程当中,LZ遇到 ...

  2. 回答阿里社招面试如何准备,顺便谈谈对于Java程序猿学习当中各个阶段的建议

    引言 其实本来真的没打算写这篇文章,主要是LZ得记忆力不是很好,不像一些记忆力强的人,面试完以后,几乎能把自己和面试官的对话都给记下来.LZ自己当初面试完以后,除了记住一些聊过的知识点以外,具体的内容 ...

  3. Java程序猿学习当中各个阶段的建议

    回答阿里社招面试如何准备,顺便谈谈对于Java程序猿学习当中各个阶段的建议   引言 其实本来真的没打算写这篇文章,主要是LZ得记忆力不是很好,不像一些记忆力强的人,面试完以后,几乎能把自己和面试官的 ...

  4. 顺便谈谈对于Java程序猿学习当中各个阶段的建议

    引言 其实本来真的没打算写这篇文章,主要是LZ得记忆力不是很好,不像一些记忆力强的人,面试完以后,几乎能把自己和面试官的对话都给记下来.LZ自己当初面试完以后,除了记住一些聊过的知识点以外,具体的内容 ...

  5. 【Python】Java程序员学习Python(五)— 函数的定义和使用

    不想做一个待宰的羔羊!!!!要自己变得强大.... 函数的定义和使用放在最前边还是有原因的,现在语言趋于通用,基本类型基本都是那些,重点还是学习对象的使用方法,而最根本的还是方法的使用,因此优先介绍, ...

  6. Java程序猿学习的建议(转)

    第一部分:对于尚未做过Java工作的同学,包括一些在校生以及刚准备转行Java的同学. 一.Java基础 首先去找一个Java的基础教程学一下,这里可以推荐一个地址,或者你也可以参照这个地址上去找相应 ...

  7. 10个Python练手小程序,学习python的很好的资料

    [程序1] 题目:有1.2.3.4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 1.程序分析:可填在百位.十位.个位的数字都是1.2.3.4.组成所有的排列后再去  掉不满足条件的排列 ...

  8. 【Python】Java程序员学习Python(三)— 基础入门

    一闪一闪亮晶晶,满天都是小星星,挂在天上放光明,好像许多小眼睛.不要问我为什么喜欢这首歌,我不会告诉你是因为有人用口琴吹给我听. 一.Python学习文档与资料 一般来说文档的资料总是最权威,最全面的 ...

  9. 【Python】Java程序员学习Python(二)— 开发环境搭建

    巧妇难为无米之炊,我最爱的还是鸡蛋羹,因为我和鸡蛋羹有段不能说的秘密. 不管学啥,都要有环境,对于程序员来说搭建个开发环境应该不是什么难题.按顺序一步步来就可以,我也只是记录我的安装过程,你也可以滴. ...

随机推荐

  1. pycharm永久激活(转载)

    转载自CSDN--http://blog.csdn.net/mr_hhh/article/details/79062747 2018-02-2417:30:52 今天再补充一个教程,关于pycharm ...

  2. Jmeter各组件介绍 及 使用

    本篇主要讲述Jmeter的各个组件及简单使用,其中包括以下内容: 一.线程组二.逻辑控制器三.配置元件四.定时器五.后置处理器六.断言七.监听器 八.参数化 网上大神整理的链接:http://blog ...

  3. Microsoft SQL Server学习(五)--操作符聚合函数

    算术运算符 逻辑运算符 比较运算符 聚合函数 算术运算符(+ - * / ) select score*2 as 成绩翻倍 from class_A update class_A set score= ...

  4. Qt杂记——布局、信号与槽等

    1.QHBoxLayout布局设置拉伸: ui->TopLayout->setStretch(,); //left ui->TopLayout->setStretch(,); ...

  5. JS的filter用法

    filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素. 和map()类似,Array的filter()也接收一个函数.和map()不同的是,filter()把传入的函 ...

  6. 「 Luogu P1231 」 教辅的组成

    题目大意 有 $\text{N1}$ 本书 $\text{N2}$本练习册 $\text{N3}$本答案,一本书只能和一本练习册和一本答案配对.给你一些书和练习册,书和答案的可能的配对关系.问你最多可 ...

  7. Linux之awk用法

    简介 awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再 ...

  8. Linux 查看发行版版本信息和内核版本

    版本信息: cat  /etc/centos-release  或 redhat-release cat  /etc/issiue 内核信息:uname -r   或   uname  -a

  9. CentOS 6 Yum本地源配置

    #cd /etc/yum.repos.d #rm CentOS-Base.repo CentOS-Base.repo 是yum 网络源的配置文件(默认) #vi CentOS-Media.repo C ...

  10. AWK简单使用方法

    1. 命令格式 gawk [OPTIONS] 'program' FILES.... program:'PATTERN{ACTION}' 一条awk命令中,PATTERN和ACTION,至少存在一个才 ...