Python语法简单,大多数情况下,根据单词的意思就可以猜测出程序的功能。
在介绍Python语法之前,先看一些Pyhton代码的案例,这些案例都很简单,可以在PyChram中运行。
打开PyCharm,我们直接新建一个Python文件(右键工程文件夹(pythonProject)-->New-->Python File)

然后弹出窗口,给文件命名,这里命名为test,按回车创建。

于是工程文件夹下就多了一个test.py文件,我们就在这里写代码。

编写完成后,右键test.py,点击运行(Run)。

代码来自:https://wiki.python.org/moin/SimplePrograms
1行:输出信息
代码:
print('Hello, world!')
运行结果:
Hello, world!
2行:输入信息
代码:
name = input('What is your name?\n')
print ('Hi, %s.' % name)
运行后,PyCharm下面的控制台会打印提示消息,What is your name?
我们点一下这句话的下面,然后就可以输入名字了。


(输入完,按回车表示输入结束)
程序得到信息,并将该信息输出:
[图片上传失败...(image-bd1ca9-1655117401367)]
3行:for循环
代码:
friends = ['john', 'pat', 'gary', 'michael']
for i, name in enumerate(friends):
print(f"friend {i} is {name}")
运行结果:
friend 0 is john
friend 1 is pat
friend 2 is gary
friend 3 is michael
4行:实现斐波那契数
代码:
parents, babies = (1, 1)
while babies < 100:
print(f'This generation has {babies} babies')
parents, babies = (babies, parents + babies)
运行结果:
This generation has 1 babies
This generation has 2 babies
This generation has 3 babies
This generation has 5 babies
This generation has 8 babies
This generation has 13 babies
This generation has 21 babies
This generation has 34 babies
This generation has 55 babies
This generation has 89 babies
5行:函数(Functions)
代码:
def greet(name):
print('Hello', name)
greet('Jack')
greet('Jill')
greet('Bob')
运行结果:
Hello Jack
Hello Jill
Hello Bob
6行:导入库,使用库的函数进行字符串匹配。
代码:
import re
for test_string in ['555-1212', 'ILL-EGAL']:
if re.match(r'^\d{3}-\d{4}$', test_string):
print(test_string, 'is a valid US local phone number')
else:
print(test_string, 'rejected')
运行结果:
555-1212 is a valid US local phone number
ILL-EGAL rejected
7行:字典,生成器表达式
代码:
prices = {'apple': 0.40, 'banana': 0.50}
my_purchase = {
'apple': 1,
'banana': 6}
grocery_bill = sum(prices[fruit] * my_purchase[fruit]
for fruit in my_purchase)
print(f'I owe the grocer {grocery_bill:.2f}$')
运行结果:
I owe the grocer 3.40$
8行:从命令行读入。程序实现了一个加法器
# This program adds up integers that have been passed as arguments in the command line
import sys
try:
total = sum(int(arg) for arg in sys.argv[1:])
print ('sum =', total)
except ValueError:
print ('Please supply integer arguments')为什么只有7行呢,因为第8行在命令行中输入:
在命令行中输入:
python test.py 1 2 3 4
点击下面的Terminal,进入命令行,输入代码。执行test.py程序。

9行(#开头的注释不算,11-2=9):读取文件
代码:
# indent your Python code to put into an email
import glob
# glob supports Unix style pathname extensions
python_files = glob.glob('*.py')
for file_name in sorted(python_files):
print(' ------' + file_name)
with open(file_name) as f:
for line in f:
print(' ' + line.rstrip())
print()
运行结果:
输出了该目录下py文件内容。
10行:获取当前时间(不算activities及其上下空格,activities相当于是数据)
代码:
from time import localtime
activities = {8: 'Sleeping',
9: 'Commuting',
17: 'Working',
18: 'Commuting',
20: 'Eating',
22: 'Resting' }
time_now = localtime()
hour = time_now.tm_hour
for activity_time in sorted(activities.keys()):
if hour < activity_time:
print (activities[activity_time])
break
else:
print ('Unknown, AFK or sleeping!')
运行结果:
我运行的时间是上午10:42,所以对应的是:
Working
11行:三引号字符串,while循环
代码:
REFRAIN = '''
%d bottles of beer on the wall,
%d bottles of beer,
take one down, pass it around,
%d bottles of beer on the wall!
'''
bottles_of_beer = 9
while bottles_of_beer > 1:
print(REFRAIN % (bottles_of_beer, bottles_of_beer,
bottles_of_beer - 1))
bottles_of_beer -= 1
运行结果:
每次句子中的bottles_of_beer减一。
12行:类。创建一个银行账户,进行存钱取钱。
代码:
class BankAccount(object):
def __init__(self, initial_balance=0):
self.balance = initial_balance
def deposit(self, amount):
self.balance += amount
def withdraw(self, amount):
self.balance -= amount
def overdrawn(self):
return self.balance < 0
my_account = BankAccount(15)
my_account.withdraw(50)
print (my_account.balance, my_account.overdrawn()):
运行结果:
-35 True
13行:使用unittest进行单元测试(Unit testing)。下面代码测试了一个取中位数的功能median。
self.assertEqual(median([2, 9, 9, 7, 9, 2, 4, 5, 8]), 7)语句,是判断函数median的结果是否和预期结果7相同。
代码:
import unittest
def median(pool):
copy = sorted(pool)
size = len(copy)
if size % 2 == 1:
return copy[int((size - 1) / 2)]
else:
return (copy[int(size/2 - 1)] + copy[int(size/2)]) / 2
class TestMedian(unittest.TestCase):
def testMedian(self):
self.assertEqual(median([2, 9, 9, 7, 9, 2, 4, 5, 8]), 7)
if __name__ == '__main__':
unittest.main()
运行结果:
D:/PY_TEST/pythonProject/test.py
Testing started at 10:49 ...
Launching unittests with arguments python -m unittest D:/PY_TEST/pythonProject/test.py in D:\PY_TEST\pythonProject
Ran 1 test in 0.002s
OK
14行:文档测试( Doctest-based testing)
def median(pool):
'''Statistical median to demonstrate doctest.
>>> median([2, 9, 9, 7, 9, 2, 4, 5, 8])
6 #change to 7 in order to pass the test
'''
copy = sorted(pool)
size = len(copy)
if size % 2 == 1:
return copy[int((size - 1) / 2)]
else:
return (copy[int(size/2 - 1)] + copy[int(size/2)]) / 2
if __name__ == '__main__':
import doctest
doctest.testmod()
运行结果:错误,预期 6 #change to 7 in order to pass the test,得到值7。
Failure
<Click to see difference>
**********************************************************************
File "D:\PY_TEST/pythonProject\test.py", line 3, in test.median
Failed example:
median([2, 9, 9, 7, 9, 2, 4, 5, 8])
Expected:
6 #change to 7 in order to pass the test
Got:
7
说明文档错误,修改代码第4行:
def median(pool):
'''Statistical median to demonstrate doctest.
>>> median([2, 9, 9, 7, 9, 2, 4, 5, 8])
7
'''
copy = sorted(pool)
size = len(copy)
if size % 2 == 1:
return copy[int((size - 1) / 2)]
else:
return (copy[int(size/2 - 1)] + copy[int(size/2)]) / 2
if __name__ == '__main__':
import doctest
doctest.testmod()
运行结果:没有错误,表示通过。
Testing started at 10:57 ...
Process finished with exit code 0
总的来说,我对ruby还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
如何在buildr项目中使用Ruby?我在很多不同的项目中使用过Ruby、JRuby、Java和Clojure。我目前正在使用我的标准Ruby开发一个模拟应用程序,我想尝试使用Clojure后端(我确实喜欢功能代码)以及JRubygui和测试套件。我还可以看到在未来的不同项目中使用Scala作为后端。我想我要为我的项目尝试一下buildr(http://buildr.apache.org/),但我注意到buildr似乎没有设置为在项目中使用JRuby代码本身!这看起来有点傻,因为该工具旨在统一通用的JVM语言并且是在ruby中构建的。除了将输出的jar包含在一个独特的、仅限ruby
Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack
在rails源中:https://github.com/rails/rails/blob/master/activesupport/lib/active_support/lazy_load_hooks.rb可以看到以下内容@load_hooks=Hash.new{|h,k|h[k]=[]}在IRB中,它只是初始化一个空哈希。和做有什么区别@load_hooks=Hash.new 最佳答案 查看rubydocumentationforHashnew→new_hashclicktotogglesourcenew(obj)→new_has
我想用ruby编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序
在选择我想要运行操作的频率时,唯一的选项是“每天”、“每小时”和“每10分钟”。谢谢!我想为我的Rails3.1应用程序运行调度程序。 最佳答案 这不是一个优雅的解决方案,但您可以安排它每天运行,并在实际开始工作之前检查日期是否为当月的第一天。 关于ruby-如何每月在Heroku运行一次Scheduler插件?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/8692687/
exe应该在我打开页面时运行。异步进程需要运行。有什么方法可以在ruby中使用两个参数异步运行exe吗?我已经尝试过ruby命令-system()、exec()但它正在等待过程完成。我需要用参数启动exe,无需等待进程完成是否有任何rubygems会支持我的问题? 最佳答案 您可以使用Process.spawn和Process.wait2:pid=Process.spawn'your.exe','--option'#Later...pid,status=Process.wait2pid您的程序将作为解释器的子进程执行。除
我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此