12 Answers

New AnswerHarsha S Python range can only generate a set of integer numbers from a given band. Neither does it allow a float type parameter nor it can produce a float range of numbers. You can use arange function from NumPy library https://www.techbeamers.com/python-float-range/

Harsha S You can't get float value of a range because a range creates a number of iterations. How can you get half an iteration? You could assign a float to your code with each iteration IE: lst = [] for i in range(5): lst.append(float(input())

Harsha S import numpy as np print(np.arange(1.5, 10.5, 0.1)) output : [ 1.5 1.6 1.7 1.8 1.9 2. 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3. 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4. 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5. 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6. 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7. 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8. 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9. 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10. 10.1 10.2 10.3 10.4] [Program finished] I hope it helped ☺️

For numbers with only one dezimal, create a range from 15 to 105 by step 1. Then divide every number by 10.

Harsha S we are programmers def frange(a, b, c): while a < b: yield a a += c for i in frange(0.1, 10.5, 0.1): print(i)

Rik Wittkopp what is half an iteration? range(a, b, c) simply means (a, a+b, a+2b, ... upto a+nb < c ). It is a limitation of the range function that it supports only integer values and I believe it's due to floating point approximation.

ａｂｈｉｎａｖ a small change: def frange(a,b,c): while a<b: yield float("%.1f"%a) a += c print(list(frange(1.5, 10.5, 0.1)))

This representation gives a range of approximately 3.4E-38 to 3.4E+38 for type float. You can declare variables as float. https://www.tellpopeyes.biz/