|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
我是python3.4,我将极半径和极角存为了2个数组,现在我想将极半径和极角通过描点的方式画出一个图形,请问怎么搞啊?
各位大神帮帮忙,没有思路中。。。
将此极半径和极角画出图像并显示。。。thank you~~
我的源码和文件如下:
import math as m
f = open('c:\\circle.txt')
data1 = []
data2 = []
temp = []
data3 = []
value1 = []
value2 = []
temp1 = ''
temp2 = ''
temp3 = ''
#字符串切片,将XYZ储存到data1 data2 data3 并#去掉data3 中的\n
for i in f:
(temp1,temp2,temp3) = i.split(' ')
data1.append(temp1)
data2.append(temp2)
temp.append(temp3)
#去除\n
for each in temp:
each = each[:16]
data3.append(each)
#确定测量点数
len1 = len(data1)
len2 = len(data2)
#转换为极坐标,并判断处于哪个象限,math库中math.atan貌似只能计算(-90)----(90),这里应该可以优化????
#将极半径存到value1
#将极角存到value2
if len1 == len2 :
for j in range(len1):
r = m.sqrt(float(data1[j])**2 + float(data2[j])**2)
value1.append(r)
if float(data1[j]) > 0 and float(data2[j]) > 0:
a = m.degrees(m.atan(float(data2[j])/float(data1[j])))
elif float(data1[j]) < 0 and float(data2[j]) > 0 :
a = 180 + m.degrees(m.atan(float(data2[j])/float(data1[j])))
elif float(data1[j]) < 0 and float(data2[j]) < 0 :
a = 180 + m.degrees(m.atan(float(data2[j])/float(data1[j])))
else:
a = 360 + m.degrees(m.atan(float(data2[j])/float(data1[j])))
value2.append(a)
else:
print('x number is diff from y number,pls check! ')
#验证
print(list(value1))
print(len(value1))
print(list(value2))
print(len(value2))
f.close()
input()
|
|