Что не так в этом коде? Он продолжает записывать одно и то же значение

#python #mysql #insert

#python #mysql #вставить

Вопрос:

он вставляет одно и то же значение каждый раз.

 import re
import MySQLdb
db = MySQLdb.connect("localhost","root","123","tc" )
cursor = db.cursor()
for x in range(1,2):
        file = '/tmp/tc/'
        file  =`x`
        file  =".txt"
        f = open(file, 'r')
        print x
        listTC = re.findall(r'[1-9]{1}[0-9]{10}', f.read())
        for item in listTC:
                print item
                sql = "INSERT INTO TCNO (tcno) VALUES(%s);"
                cursor.execute(sql % (item))
  

ВЫВОД на СЕРВЕР MYSQL:

 | 94006 | 2147483647 | NULL |
| 94007 | 2147483647 | NULL |
| 94008 | 2147483647 | NULL |
| 94009 | 2147483647 | NULL |
| 94010 | 2147483647 | NULL |
| 94011 | 2147483647 | NULL |
| 94012 | 2147483647 | NULL |
| 94013 | 2147483647 | NULL |
| 94014 | 2147483647 | NULL |
| 94015 | 2147483647 | NULL |
| 94016 | 2147483647 | NULL |
| 94017 | 2147483647 | NULL |
| 94018 | 2147483647 | NULL |
| 94019 | 2147483647 | NULL |
| 94020 | 2147483647 | NULL |
| 94021 | 2147483647 | NULL |
| 94022 | 2147483647 | NULL |
| 94023 | 2147483647 | NULL |
 ------- ------------ ------ 
94023 rows in set (0.11 sec)
  

Однако в консоли, когда я печатаю элемент:

 69619195972
32386362700
70930135288
20371250224
25069684954
32414357302
55660438298
12352807312
18566819172
53425735712
19622042220
34060374108
49126586180
13184124554
18772590346
38074262024
37765310686
15491265104
16139670014
16799684314
22231833554
22231833554
21389016246
44923993452
50902266134
30742937128
34071994144
35011994174
  

Комментарии:

1. Что печатается для x и item ?

2. Было бы полезно [критически] узнать содержимое f .

3. x — это имя файла 50. Поэтому он будет открывать файлы в этом диапазоне, а элемент — это числа в файлах. С item проблем нет. Он печатает уникальные числа. Однако, когда я просматриваю базы данных. Есть одно число и несколько строк

4. ничего важного, он получает числа в файле и помещает в listTC.Кроме того, я проверяю номер с помощью печати элемента. Оно всегда уникально.

5. И все ваши print sql % (item) утверждения верны?

Ответ №1:

2147483647 является 0x7fffffff , так что, вероятно, вы достигли максимального значения int со знаком.

Взгляните на тип данных в поле у разработчиков баз данных и, вероятно, используйте Big Integer или что-то еще большее.

ссылка: http://dev.mysql.com/doc/refman/5.0/en/numeric-types.html#id603844

Ответ №2:

Это из-за range(1,2):

 for x in range(1,2):
...   print x
...
1
for x in range(0,2):
...   print x
...
0
1