Форум программистов, компьютерный форум CyberForum.ru

Программирование Android

Войти
Регистрация
Восстановить пароль
 
Soprano6111
2 / 2 / 0
Регистрация: 09.04.2015
Сообщений: 90
#1

Крашиться при запросе String number = c.getString(c.getColumnIndex("address"); - Программирование Android

11.09.2015, 13:12. Просмотров 238. Ответов 3
Метки нет (Все метки)

http://rghost.ru/6FKfffYZG

крашится на 88 строке

почему?

проект - http://rghost.ru/6FKfffYZG

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
package com.vrs.smsapp;
 
/***
 *    Application Name : MessageBox 
 *    Author : Vimal Rughani
 *    Website : [url]http://pulse7.net[/url]
 *    For more details visit [url]http://pulse7.net/android/read-sms-message-inbox-sent-draft-android/[/url]
 */
 
import android.app.Activity;
import android.content.ContentResolver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;
 
public class MessageBox extends Activity implements OnClickListener {
    String[] Inbox_name=new String[100],
            Inbox_number=new String[100],
            Inbox_date=new String[100],
            Inbox_type=new String[100],
            Inbox_msg=new String[100];
 
     int pos=0;
    // GUI Widget
    Button btnSent, btnInbox, btnDraft;
    TextView lblMsg, lblNo;
    ListView lvMsg;
 
    // Cursor Adapter
    SimpleCursorAdapter adapter;
 
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.messagebox);
 
        // Init GUI Widget
        btnInbox = (Button) findViewById(R.id.btnInbox);
        btnInbox.setOnClickListener(this);
 
        btnSent = (Button) findViewById(R.id.btnSentBox);
        btnSent.setOnClickListener(this);
 
        btnDraft = (Button) findViewById(R.id.btnDraft);
        btnDraft.setOnClickListener(this);
 
        lvMsg = (ListView) findViewById(R.id.lvMsg);
 
    }
 
    @Override
    public void onClick(View v) {
 
        if (v == btnInbox) {
 
            // Create Inbox box URI
            Uri inboxURI = Uri.parse("content://sms/inbox");
 
            // List required columns
    //      String[] reqCols = new String[] { "_id", "thread_id", "address", "person", "date",
        //          "body", "type" };
 
            // Get Content Resolver object, which will deal with Content
            // Provider
            ContentResolver cr = getContentResolver();
 
            // Fetch Inbox SMS Message from Built-in Content Provider
            Cursor c = cr.query(inboxURI,
                    new String[] { "_id", "thread_id", "address", "person", "date",
                            "body", "type" }, null, null, null); //"address like '+79034320258'"
 
 
 
            String[] columns =  new String[] {"address", "person", "date", "body",
                    "type"};
 
 
/*
            if (c.getCount() > 0) {
 
                String number = c.getString(c.getColumnIndex("address"));
                String name = c.getString(c.getColumnIndex("person"));//c.getString(c.getColumnIndex(columns[1]));
                String date = c.getString(c.getColumnIndex("date"));//c.getString(c.getColumnIndex(columns[2]));
                String msg =  c.getString(c.getColumnIndex("body"));//c.getString(c.getColumnIndex(columns[3]));
                String type =  c.getString(c.getColumnIndex("type"));//c.getString(c.getColumnIndex(columns[4]));
 
                //b.append(c.getString(c.getColumnIndex("type")));
 
            //  String number = c.getString(c.getColumnIndex("address"));
            //  String number = c.getString(c.getColumnIndex(columns[1]));
 
 
                Inbox_name[pos]= name;
                Inbox_number[pos] =number;
 
                if(date!=null)
                {
                    long l = Long.parseLong(date);
                    Date d = new Date(l);
                    Inbox_date[pos]= DateFormat.getDateInstance(DateFormat.LONG).format(d);
                    Inbox_type[pos]= DateFormat.getTimeInstance().format(d);
                }
                else
                {
                    Inbox_date[pos]=date;
                    Inbox_type[pos]=type;
                }
 
                Inbox_msg[pos]=msg;
                pos +=1;
            }
 
*/
 
            adapter = new SimpleCursorAdapter(this, R.layout.row, c,
                    columns, new int[] {
                    R.id.lblNumber, 0 , R.id.lblDate ,R.id.lblMsg ,R.id.lblTime});
 
 
            lvMsg.setAdapter(adapter);
 
//          lvMsg.setAdapter(new InboxArrayAdapter(this,Inbox_name,Inbox_number,Inbox_date,Inbox_type,Inbox_msg));
 
            // Attached Cursor with adapter and display in listview
/*
 
            String date = c.getString(c.getColumnIndex(columns[3]));
 
 
            if(date!=null)
            {
                long l = Long.parseLong(date);
                Date d = new Date(l);
                //Inbox_date[pos]
                    String date2;
                date2       = DateFormat.getDateInstance(DateFormat.LONG).format(d);
            //  Inbox_type[pos]
                String time2;
                time2       =DateFormat.getTimeInstance().format(d);
            }
 
        */
 
 
 
        }
 
 
 
        if (v == btnSent) {
 
            // Create Sent box URI
            Uri sentURI = Uri.parse("content://sms/sent");//sent
 
            // List required columns
            String[] reqCols = new String[] { "_id", "address", "body" };
 
            // Get Content Resolver object, which will deal with Content
            // Provider
            ContentResolver cr = getContentResolver();
 
            // Fetch Sent SMS Message from Built-in Content Provider
            Cursor c = cr.query(sentURI, reqCols, "address like '%+79034320258%'" , null, null);//"address like '+79034320258'"
 
            // Attached Cursor with adapter and display in listview
            adapter = new SimpleCursorAdapter(this, R.layout.row, c,
                    new String[] { "body", "address" }, new int[] {
                            R.id.lblMsg, R.id.lblNumber });
            lvMsg.setAdapter(adapter);
 
        }
 
        if (v == btnDraft) {
            // Create Draft box URI
            Uri draftURI = Uri.parse("content://sms/draft");
 
            // List required columns
            String[] reqCols = new String[] { "_id", "address", "body" };
 
            // Get Content Resolver object, which will deal with Content
            // Provider
            ContentResolver cr = getContentResolver();
 
            // Fetch Sent SMS Message from Built-in Content Provider
            Cursor c = cr.query(draftURI, reqCols, "address like '+79034320258'", null, null);
 
            // Attached Cursor with adapter and display in listview
            adapter = new SimpleCursorAdapter(this, R.layout.row, c,
                    new String[] { "body", "address" }, new int[] {
                            R.id.lblMsg, R.id.lblNumber });
            lvMsg.setAdapter(adapter);
 
        }
 
    }
}
Добавлено через 25 минут
В докуметации - abstract String getString(int columnIndex)
Returns the value of the requested column as a String.


но крашится ...
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.09.2015, 13:12
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Крашиться при запросе String number = c.getString(c.getColumnIndex("address"); (Программирование Android):

Как "превратить" string "6.971245e-001" во float? - Программирование Android
Число конечно пример

При эмулировании вместо надписи "Hello world" отображается "android" - Программирование Android
Привет форумчане! Я только-только начинал программировать на андроиде. Поставил среду, все настроил как на google.developers . Когда...

String.format("%.2f", var). запятую в точку - Программирование Android
Имеется код double AfterCopper = Кое-какие вычисления; String AfterCopper2 = String.format("%.2f", AfterCopper); У...

Работа с БД, связывание таблиц "фильмы", "жанры", "режиссеры" - Программирование Android
Ребят, всем привет! накидайте какие-нить идеи по реализации ситуация такая есть таблицы - "списки_жанров", "фильмы", "режиссеры" мне...

Ошибка "Unknown method "e" of "org.apache.commons.logging.Log" - Программирование Android
Unknown method 'e' of 'org.apache.commons.logging.Log' package com.mycompany.myapp; import android.widget.*; import...

"Ошибка при синтаксическом анализе пакета" при скачивании файла - Программирование Android
Пытаюсь сделать обновление в своем приложении. Должно быть так: скачивается файл приложения и устанавливается. только вот скачивается он...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
vxg
Модератор
3157 / 1959 / 218
Регистрация: 13.01.2012
Сообщений: 7,492
11.09.2015, 13:19 #2
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от Soprano6111 Посмотреть сообщение
крашится
наверное такого поля нет
getColumnIndex(String columnName) Returns the zero-based index for the given column name, or -1 if the column doesn't exist.
Pablito
2472 / 1917 / 595
Регистрация: 12.05.2014
Сообщений: 6,741
Завершенные тесты: 1
11.09.2015, 13:24 #3
архив по первой ссылке блокируется как содержащий вирус
и это уже второй случай когда этот тип выкладывает что-то куда-то вместо того что бы показывать скриншоты и текст на форуме
Soprano6111
2 / 2 / 0
Регистрация: 09.04.2015
Сообщений: 90
11.09.2015, 15:27  [ТС] #4
Ответили , спасибо ,тему можно закрывать.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
11.09.2015, 15:27
Привет! Вот еще темы с ответами:

SharedPreferences. Чудеса при putString/getString - Программирование Android
static SharedPreferences mSettings = PreferenceManager.getDefaultSharedPreferences(this); String value_1 = "trade1.db"; ...

Постепенно вывести на экран слово "Java", в котором буквы состоят из "интересных" элементов - Программирование Android
Я учусь в универе и вот пытаюсь делать лабораторные по языку java, только на свой телефон с помощью android studio )) До этого все...

Выбор платформы разработки "1С Мобильная платформа" или "Android Studio" - Программирование Android
Всем, здравствуйте! Есть задача по разработке клиента для терминала сбора данных. Для использования его c WMS. После долгих раздумий было...

Как прикрутить "свой браузер" к странице - "фрагмент" - Программирование Android
здравствуйте. все, уже голову сломал. не соображаю совсем. не получается прикрутить код браузера к странице fragments.выводиться должно на-...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
11.09.2015, 15:27
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru